:root {
    --primary: #0b5fe8;
    --primary-dark: #0847ad;
    --ink: #172033;
    --muted: #667085;
    --line: #e6eaf2;
    --page: #f4f7fb;
}

* { box-sizing: border-box; }
body { margin: 0; font-family: Poppins, Arial, sans-serif; color: var(--ink); background: var(--page); }
a { text-decoration: none; }

.auth-bg { min-height: 100vh; display: grid; place-items: center; background: linear-gradient(135deg, #eef5ff, #f7f9fc); }
.auth-card { width: min(420px, calc(100vw - 32px)); background: #fff; padding: 32px; border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 24px 60px rgba(23, 32, 51, .12); }
.auth-card h1 { font-size: 28px; margin: 14px 0 4px; }
.brand-mark, .sidebar-brand span { width: 44px; height: 44px; display: inline-grid; place-items: center; border-radius: 8px; background: var(--primary); color: #fff; font-weight: 700; }
.sidebar-brand span { overflow: hidden; background: #fff; border: 1px solid var(--line); }
.sidebar-brand img { width: 100%; height: 100%; display: block; object-fit: contain; }

.app-shell { min-height: 100vh; display: grid; grid-template-columns: 260px 1fr; transition: grid-template-columns .2s ease; }
body.sidebar-collapsed .app-shell { grid-template-columns: 84px 1fr; }
.sidebar { background: #fff; border-right: 1px solid var(--line); padding: 18px 14px; position: sticky; top: 0; height: 100vh; overflow-x: hidden; overflow-y: auto; z-index: 1040; }
.sidebar-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 24px; }
.sidebar-brand { min-width: 0; display: flex; align-items: center; gap: 12px; color: var(--ink); }
.sidebar-brand strong, .sidebar-nav a span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sidebar-nav { display: grid; gap: 4px; }
.sidebar-nav a { color: #48556a; min-height: 44px; padding: 11px 12px; border-radius: 8px; display: flex; align-items: center; gap: 10px; font-size: 14px; }
.sidebar-nav a i { width: 20px; flex: 0 0 20px; text-align: center; font-size: 17px; }
.sidebar-nav a.active, .sidebar-nav a:hover { background: #edf4ff; color: var(--primary-dark); }
body.sidebar-collapsed .sidebar { padding-inline: 12px; }
body.sidebar-collapsed .sidebar-head { justify-content: center; }
body.sidebar-collapsed .sidebar-brand { justify-content: center; }
body.sidebar-collapsed .sidebar-brand strong, body.sidebar-collapsed .sidebar-nav a span { display: none; }
body.sidebar-collapsed .sidebar-nav a { justify-content: center; padding-inline: 10px; }
body.sidebar-collapsed .desktop-toggle { position: fixed; left: 58px; top: 22px; background: #fff; box-shadow: 0 10px 25px rgba(23, 32, 51, .12); }
.sidebar-icon-btn { width: 38px; height: 38px; border: 1px solid var(--line); border-radius: 8px; display: inline-grid; place-items: center; background: #fff; color: #48556a; transition: background .15s ease, color .15s ease, border-color .15s ease; }
.sidebar-icon-btn:hover { background: #edf4ff; border-color: #cfe1ff; color: var(--primary-dark); }
.mobile-close, .mobile-menu, .sidebar-backdrop { display: none; }
.main { padding: 24px; min-width: 0; }
.topbar { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin-bottom: 22px; }
.topbar-title { min-width: 0; display: flex; align-items: center; gap: 12px; }
.topbar h1 { margin: 0; font-size: 28px; font-weight: 700; }
.topbar-user { display: flex; align-items: center; gap: 10px; }

.panel { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 18px; box-shadow: 0 12px 30px rgba(23, 32, 51, .04); }
.panel-title { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
.grid-cards { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.metric { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 16px; }
.metric span { color: var(--muted); font-size: 13px; }
.metric strong { display: block; font-size: 30px; margin-top: 8px; }
.table { vertical-align: middle; }
.table thead th { color: var(--muted); font-size: 12px; text-transform: uppercase; white-space: nowrap; }
.table-responsive { overflow-x: auto; }
.actions { display: flex; align-items: center; gap: 6px; justify-content: flex-end; }
.filters { display: grid; grid-template-columns: repeat(6, minmax(150px, 1fr)); gap: 10px; margin-bottom: 16px; }
.crm-filters { grid-template-columns: repeat(8, minmax(130px, 1fr)); margin-bottom: 0; }
.bulk-actions { display: flex; justify-content: flex-end; gap: 8px; margin-bottom: 10px; }
.pagination-bar { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-top: 14px; }
.pagination-actions { display: flex; gap: 8px; }
.inline-input, .inline-select { min-width: 140px; }
.status-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; margin-right: 6px; }
.label-sheet { display: grid; grid-template-columns: repeat(auto-fill, minmax(10cm, 1fr)); gap: 12px; }
.shipping-label { width: 10cm; height: 15cm; background: #fff; color: #111; padding: 12mm; border: 1px solid #111; page-break-after: always; display: flex; flex-direction: column; justify-content: space-between; }
.shipping-label h2 { font-size: 28px; margin: 0; }
.shipping-label .label-city { font-size: 28px; font-weight: 700; margin: 0; line-height: 1.2; }
.shipping-label .volume { font-size: 44px; font-weight: 800; text-align: center; border: 2px solid #111; padding: 8px; }
.qr-box { width: 64px; height: 64px; display: grid; place-items: center; border: 2px solid #111; font-weight: 700; }
.print-toolbar { position: sticky; top: 0; z-index: 2; background: var(--page); padding: 10px 0; }
.stockkeeper-focused-layout { background: #eef3f8; }
.stockkeeper-shell { min-height: 100vh; }
.stockkeeper-main { width: min(1680px, 100%); margin: 0 auto; padding: 16px; }
.stockkeeper-nav { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-bottom: 12px; }
.stockkeeper-nav a { min-height: 42px; display: inline-flex; align-items: center; gap: 8px; padding: 9px 13px; border: 1px solid var(--line); border-radius: 8px; background: #fff; color: #48556a; font-size: 14px; font-weight: 600; box-shadow: 0 8px 22px rgba(23, 32, 51, .05); }
.stockkeeper-nav a.active, .stockkeeper-nav a:hover { border-color: #b9d4ff; background: #eaf3ff; color: var(--primary-dark); }
.stockkeeper-nav .stockkeeper-logout-link { margin-left: auto; }
.stockkeeper-focused-layout .panel { box-shadow: 0 10px 26px rgba(23, 32, 51, .05); }
.stockkeeper-focused-layout .filters { grid-template-columns: minmax(260px, 1.6fr) repeat(5, minmax(130px, 1fr)); }
.stockkeeper-focused-layout .orders-table { font-size: 14px; }
.stockkeeper-focused-layout .print-toolbar { top: 0; display: flex; flex-wrap: wrap; gap: 8px; background: #eef3f8; }
.stockkeeper-empty-panel { min-height: 120px; display: flex; align-items: center; }
.confirm-modal { border: 0; border-radius: 8px; box-shadow: 0 24px 70px rgba(23, 32, 51, .2); }
.confirm-modal .modal-body { display: grid; grid-template-columns: 52px 1fr; gap: 14px; padding: 22px 22px 12px; }
.confirm-modal .modal-footer { border-top: 0; padding: 12px 22px 22px; }
.confirm-icon { width: 52px; height: 52px; display: grid; place-items: center; border-radius: 8px; color: #b42318; background: #fee4e2; font-size: 22px; }
.search-select { min-width: 0; }
.search-select-control { min-height: 252px; }
.orders-table td, .orders-table th { white-space: nowrap; }
.orders-table tbody tr.order-row-sem-situacao > td { background: #e7f3ff; }
.orders-table tbody tr.order-row-alterado > td { background: #fff3cd; }
.orders-table tbody tr.order-row-entregue > td { background: #ffe8cc; }
.orders-table tbody tr.order-row-coletado > td { background: #eee5ff; }
.orders-table tbody tr.order-row-em-separacao > td { background: #fde2e4; }
.orders-table tbody tr.order-row-separado > td { background: #dff3e4; }
.routes-table tbody tr.route-row-finalizada-parcialmente > td { background: #fde2e4; }
.orders-note-cell { max-width: 280px; white-space: normal !important; line-height: 1.4; }
.order-volume-input { width: 68px; min-width: 68px; max-width: 68px; text-align: center; }
.inline-select-group { min-width: 180px; }
.notification-stack { position: fixed; top: 18px; right: 18px; width: min(420px, calc(100vw - 32px)); display: grid; gap: 10px; z-index: 1120; pointer-events: none; }
.notification { pointer-events: auto; display: grid; grid-template-columns: 40px 1fr 32px; align-items: start; gap: 12px; padding: 14px; background: #fff; border: 1px solid var(--line); border-left: 4px solid var(--primary); border-radius: 8px; box-shadow: 0 18px 45px rgba(23, 32, 51, .16); animation: notification-in .18s ease-out; }
.notification > i { width: 40px; height: 40px; display: grid; place-items: center; border-radius: 8px; background: #edf4ff; color: var(--primary); font-size: 18px; }
.notification strong { display: block; font-size: 14px; margin-bottom: 2px; }
.notification p { margin: 0; color: #48556a; font-size: 13px; line-height: 1.4; }
.notification-close { width: 32px; height: 32px; border: 0; border-radius: 8px; display: grid; place-items: center; background: transparent; color: #667085; }
.notification-close:hover { background: #f2f4f7; color: var(--ink); }
.notification-success { border-left-color: #198754; }
.notification-success > i { background: #eaf7ee; color: #198754; }
.notification-danger { border-left-color: #dc3545; }
.notification-danger > i { background: #fdecef; color: #b42318; }
.notification-warning { border-left-color: #f59f00; }
.notification-warning > i { background: #fff4db; color: #b76e00; }
.notification.is-hiding { animation: notification-out .16s ease-in forwards; }
.sales-import-progress { height: 28px; border-radius: 8px; background: #edf2f7; }
.sales-import-progress .progress-bar { background: var(--primary); font-weight: 600; }
.sales-import-status { color: var(--muted); font-size: 13px; }
.sales-folder-import-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 8px; }
.sales-folder-import-stats span { display: grid; gap: 2px; padding: 10px; border: 1px solid var(--line); border-radius: 8px; background: #fbfcff; color: var(--muted); font-size: 12px; }
.sales-folder-import-stats strong { color: var(--ink); font-size: 20px; line-height: 1; }
.sales-import-errors { border: 1px solid #f1b5bd; border-left: 4px solid #dc3545; border-radius: 8px; padding: 12px; background: #fff5f6; color: #842029; font-size: 13px; }
.sales-import-errors ul { padding-left: 18px; margin-top: 8px; }
.sales-import-errors li { line-height: 1.35; overflow-wrap: anywhere; }
.route-print-sheet { display: grid; gap: 18px; }
.route-print-header { display: flex; justify-content: space-between; gap: 18px; align-items: flex-start; border-bottom: 1px solid var(--line); padding-bottom: 16px; }
.route-print-header h2 { margin: 2px 0 6px; font-size: 28px; }
.route-print-summary { display: grid; gap: 4px; justify-items: end; text-align: right; }
.route-print-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; }
.route-print-grid > div { border: 1px solid var(--line); border-radius: 8px; padding: 12px; background: #fbfcff; }
.route-print-grid span, .route-print-grid small { display: block; color: var(--muted); font-size: 12px; }
.route-print-grid strong { display: block; margin-top: 4px; font-size: 16px; }
.route-print-notes { border: 1px solid var(--line); border-radius: 8px; padding: 12px; background: #fff; }
.route-print-notes p { margin: 6px 0 0; color: #48556a; }
.route-print-table td { vertical-align: top; white-space: normal; }
.route-delivery-form { border: 1px solid var(--line); border-radius: 8px; padding: 14px; background: #fbfcff; }
.route-delivery-head { display: flex; justify-content: space-between; gap: 12px; align-items: center; }
.route-delivery-head .form-select { min-width: 230px; }
.route-builder-page { width: min(760px, 100%); margin: 0 auto; padding-bottom: 86px; }
.route-builder-top { display: flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.route-builder-top h2 { margin: 0; font-size: 28px; font-weight: 700; }
.route-builder-form { display: grid; gap: 14px; }
.route-builder-card { background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 16px; box-shadow: 0 12px 30px rgba(23, 32, 51, .04); }
.route-builder-map-card { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 10px; }
.route-builder-status { grid-column: 1 / -1; min-height: 18px; color: var(--muted); font-size: 13px; }
.route-stop-list { display: grid; gap: 10px; }
.route-stop-card { display: grid; grid-template-columns: 40px 34px 1fr 42px; gap: 10px; align-items: center; background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 12px; box-shadow: 0 14px 34px rgba(23, 32, 51, .06); }
.route-stop-card-filial { border-color: #7c3aed; background: #f7f2ff; box-shadow: 0 16px 38px rgba(124, 58, 237, .14); }
.route-stop-card-partial { border-color: #f59e0b; background: #fff7ed; box-shadow: 0 16px 38px rgba(245, 158, 11, .16); }
.route-stop-card-unit-transfer { border-color: #0891b2; background: #ecfeff; box-shadow: 0 16px 38px rgba(8, 145, 178, .14); }
.route-stop-card-fixed { border-style: dashed; background: #fbfcff; }
.route-stop-card.is-dragging { opacity: .55; border-color: var(--primary); box-shadow: 0 18px 45px rgba(11, 95, 232, .18); }
.route-stop-position { width: 40px; height: 40px; display: grid; place-items: center; border-radius: 8px; background: #edf4ff; color: var(--primary-dark); font-weight: 700; }
.route-stop-card-partial .route-stop-position { background: #ffedd5; color: #9a3412; }
.route-stop-card-unit-transfer .route-stop-position { background: #cffafe; color: #155e75; }
.route-stop-check { width: 34px; display: grid; place-items: center; margin: 0; }
.route-stop-main { min-width: 0; }
.route-stop-line { display: flex; justify-content: space-between; gap: 8px; color: var(--muted); font-size: 12px; }
.route-stop-line strong { color: var(--ink); font-size: 13px; }
.route-stop-main h3 { margin: 4px 0 2px; font-size: 17px; font-weight: 700; }
.route-stop-main p { margin: 0; color: #48556a; font-size: 13px; line-height: 1.4; overflow-wrap: anywhere; }
.route-stop-branch-badge { display: inline-flex; align-items: center; gap: 5px; width: fit-content; margin-top: 6px; padding: 3px 8px; border-radius: 999px; background: #ede9fe; color: #5b21b6; font-size: 12px; font-weight: 700; }
.route-stop-partial-badge { display: inline-flex; align-items: center; gap: 5px; width: fit-content; margin-top: 6px; padding: 3px 8px; border-radius: 999px; background: #ffedd5; color: #9a3412; font-size: 12px; font-weight: 700; }
.route-stop-unit-badge { display: inline-flex; align-items: center; gap: 5px; width: fit-content; margin-top: 6px; padding: 3px 8px; border-radius: 999px; background: #cffafe; color: #155e75; font-size: 12px; font-weight: 700; }
.route-stop-client { display: block; margin-top: 4px; color: #4b5563; line-height: 1.35; }
.route-stop-pickup { display: block; margin: 4px 0 6px; color: #5b21b6; font-weight: 600; line-height: 1.35; }
.route-stop-warning { display: inline-flex; align-items: center; gap: 4px; margin-top: 6px; color: #b76e00; }
.route-stop-actions { display: grid; gap: 5px; justify-items: center; }
.route-stop-icon, .route-stop-handle { width: 34px; height: 30px; border: 1px solid var(--line); border-radius: 8px; display: grid; place-items: center; background: #fff; color: #48556a; }
.route-stop-icon:hover { background: #edf4ff; color: var(--primary-dark); }
.route-stop-handle { cursor: grab; }
.import-tabs { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.import-tabs a { min-height: 38px; display: inline-flex; align-items: center; padding: 8px 12px; border: 1px solid var(--line); border-radius: 8px; color: #48556a; background: #fff; font-size: 13px; font-weight: 600; }
.import-tabs a.active, .import-tabs a:hover { color: var(--primary-dark); background: #edf4ff; border-color: #cfe1ff; }
.import-dashboard { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.import-filters { grid-template-columns: repeat(7, minmax(140px, 1fr)); }
.import-suggestion-table { font-size: 12px; }
.import-suggestion-table th, .import-suggestion-table td { white-space: nowrap; }
.import-suggestion-table td:nth-child(3), .import-justification-cell { min-width: 260px; max-width: 420px; white-space: normal !important; line-height: 1.35; }
.import-suggestion-table tbody tr.import-urgency-critico > td { background: #fde2e4; }
.import-suggestion-table tbody tr.import-urgency-alto > td { background: #fff3cd; }
.import-suggestion-table tbody tr.import-urgency-medio > td { background: #e7f3ff; }
.import-suggestion-table tbody tr.import-urgency-baixo > td { background: #e7f5ec; }
.import-chart { display: grid; gap: 10px; }
.import-chart-row { display: grid; grid-template-columns: minmax(120px, 180px) 1fr minmax(82px, auto); align-items: center; gap: 10px; font-size: 12px; color: #48556a; }
.import-chart-row div { height: 12px; border-radius: 999px; background: #edf2f7; overflow: hidden; }
.import-chart-row i { display: block; height: 100%; border-radius: inherit; background: var(--primary); }
.import-chart-row strong { text-align: right; color: var(--ink); font-size: 12px; }
.import-help-formula { border: 1px solid #cfe1ff; border-radius: 8px; padding: 12px; background: #f6f9ff; color: var(--primary-dark); font-weight: 600; line-height: 1.45; }
.import-order-items { min-width: 1160px; }
.import-order-items select { min-width: 260px; }
.import-order-items input { min-width: 110px; }
.import-order-items .import-product-search { min-width: 260px; }
.import-remove-item-btn { width: 34px; height: 32px; display: inline-grid; place-items: center; padding: 0; }
.import-qty-input { width: 110px; min-width: 110px; }
.import-order-summary { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
.import-order-summary span { display: inline-flex; gap: 5px; align-items: center; padding: 8px 10px; border: 1px solid var(--line); border-radius: 8px; background: #fbfcff; color: #48556a; font-size: 13px; }
.import-product-bulk-form { display: grid; grid-template-columns: minmax(180px, 1fr) 180px 140px 140px auto minmax(220px, 1fr); gap: 10px; align-items: end; padding: 12px; border: 1px solid var(--line); border-radius: 8px; background: #fbfcff; }
.import-product-settings-table { min-width: 1120px; table-layout: fixed; }
.import-product-settings-table th, .import-product-settings-table td { vertical-align: middle; }
.import-product-select-col { width: 40px; }
.import-product-name-col { width: 32%; }
.import-product-category-col { width: 22%; }
.import-product-origin-col { width: 140px; }
.import-product-square-col { width: 110px; }
.import-product-weight-col { width: 110px; }
.import-product-stock-col { width: 130px; }
.import-product-action-col { width: 86px; }
.empty-state { min-height: 160px; display: grid; place-items: center; text-align: center; color: var(--muted); background: #fff; border: 1px dashed #cbd5e1; border-radius: 8px; padding: 24px; }
.route-sticky-actions { position: sticky; bottom: 12px; z-index: 20; display: grid; grid-template-columns: 1fr 1fr; gap: 10px; padding: 10px; background: rgba(255, 255, 255, .94); border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 18px 45px rgba(23, 32, 51, .18); backdrop-filter: blur(10px); }
.route-sticky-actions .btn { min-height: 46px; font-weight: 600; }
.route-builder-empty { min-height: 220px; display: grid; place-items: center; align-content: center; gap: 8px; text-align: center; color: var(--muted); background: #fff; border: 1px dashed #cbd5e1; border-radius: 8px; padding: 28px; }
.route-builder-empty i { font-size: 34px; color: var(--primary); }
.route-builder-empty strong { color: var(--ink); }

@keyframes notification-in {
    from { opacity: 0; transform: translateY(-8px) translateX(10px); }
    to { opacity: 1; transform: translateY(0) translateX(0); }
}

@keyframes notification-out {
    to { opacity: 0; transform: translateY(-6px) translateX(10px); }
}

@media (max-width: 980px) {
    .app-shell, body.sidebar-collapsed .app-shell { grid-template-columns: 1fr; }
    .sidebar { width: min(320px, calc(100vw - 32px)); position: fixed; left: 0; top: 0; bottom: 0; height: 100dvh; transform: translateX(-105%); transition: transform .2s ease; box-shadow: 20px 0 50px rgba(23, 32, 51, .16); }
    body.mobile-sidebar-open .sidebar { transform: translateX(0); }
    .sidebar-backdrop { position: fixed; inset: 0; background: rgba(23, 32, 51, .45); z-index: 1035; }
    body.mobile-sidebar-open .sidebar-backdrop { display: block; }
    body.sidebar-collapsed .sidebar-brand strong, body.sidebar-collapsed .sidebar-nav a span { display: inline; }
    body.sidebar-collapsed .sidebar-head { justify-content: space-between; }
    body.sidebar-collapsed .sidebar-brand { justify-content: flex-start; }
    body.sidebar-collapsed .sidebar-nav a { justify-content: flex-start; padding-inline: 12px; }
    body.sidebar-collapsed .desktop-toggle { position: static; box-shadow: none; }
    .desktop-toggle { display: none; }
    .mobile-close, .mobile-menu { display: inline-grid; }
    .main { padding: 16px; }
    .grid-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .stockkeeper-focused-layout .filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .crm-filters { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .topbar { align-items: flex-start; flex-direction: column; }
}

@media (max-width: 560px) {
    .grid-cards, .filters { grid-template-columns: 1fr; }
    .stockkeeper-focused-layout .filters { grid-template-columns: 1fr; }
    .sales-folder-import-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .pagination-bar { align-items: stretch; flex-direction: column; }
    .pagination-actions .btn { flex: 1; }
    .topbar-user { width: 100%; flex-wrap: wrap; }
    .topbar h1 { font-size: 24px; }
    .notification-stack { top: 10px; right: 10px; left: 10px; width: auto; }
    .notification { grid-template-columns: 36px 1fr 32px; padding: 12px; }
    .notification > i { width: 36px; height: 36px; }
    .route-builder-page { padding-bottom: 96px; }
    .route-builder-top h2 { font-size: 24px; }
    .route-builder-map-card { grid-template-columns: 1fr; }
    .route-builder-map-card .btn { width: 100%; }
    .route-stop-card { grid-template-columns: 36px 28px 1fr; align-items: start; }
    .route-stop-position { width: 36px; height: 36px; }
    .route-stop-line { flex-direction: column; gap: 2px; }
    .route-stop-actions { grid-column: 1 / -1; grid-template-columns: repeat(3, 1fr); }
    .route-stop-icon, .route-stop-handle { width: 100%; height: 38px; }
    .route-sticky-actions { left: 16px; right: 16px; bottom: 10px; grid-template-columns: 1fr; }
    .import-dashboard { grid-template-columns: 1fr; }
    .import-product-bulk-form { grid-template-columns: 1fr; }
    .import-chart-row { grid-template-columns: 1fr; }
    .import-chart-row strong { text-align: left; }
}

@media print {
    body { background: #fff; }
    .sidebar, .topbar, .print-toolbar, .no-print { display: none !important; }
    .app-shell { display: block; }
    .main { padding: 0; }
    .panel { border: 0; padding: 0; box-shadow: none; }
    .route-print-grid { grid-template-columns: repeat(4, 1fr); }
    .route-print-table { font-size: 12px; }
    @page { size: A4; margin: 10mm; }
    .route-print-sheet { padding: 12mm; }
    .label-sheet { display: block; }
    .shipping-label { border: 0; width: 10cm; height: 15cm; }
}
