/* =====================================================
   Dania Kitchen — Design System
   Warm palette · RTL-first · Mobile-first
   Bootstrap 5 RTL overlay — no extra libraries
   ===================================================== */

/* ── 1. Design Tokens ──────────────────────────────── */
:root {
    /* Brand */
    --dk-primary-dark:    #4B2E1F;
    --dk-primary:         #7A4A2A;
    --dk-secondary:       #B9855A;
    --dk-ink:             #2d2520;
    --dk-muted:           #7a6a60;

    /* Surfaces */
    --dk-bg:              #F7F1EA;
    --dk-panel:           #FFF9F2;
    --dk-border:          #E6D8CB;

    /* Semantic */
    --dk-success:         #1d6e3c;
    --dk-success-bg:      #d4eddf;
    --dk-warning:         #854d0a;
    --dk-warning-bg:      #fdeeca;
    --dk-danger:          #9b1c15;
    --dk-danger-bg:       #fde0de;
    --dk-info:            #1e4a72;
    --dk-info-bg:         #d6e8f7;

    /* Shape */
    --dk-radius:          10px;
    --dk-radius-sm:       7px;
    --dk-shadow:          0 1px 4px rgba(75, 46, 31, .08);
    --dk-shadow-md:       0 3px 14px rgba(75, 46, 31, .12);
}

/* ── 2. Base ────────────────────────────────────────── */
html, body {
    min-width: 320px;
    overflow-x: hidden;
}

body {
    background: var(--dk-bg);
    color: var(--dk-ink);
    display: flex;
    flex-direction: column;
    font-family: 'Segoe UI', Tahoma, Arial, sans-serif;
    min-height: 100vh;
}

a { color: var(--dk-primary); }
a:hover { color: var(--dk-primary-dark); }

/* ── 3. Shell ───────────────────────────────────────── */
.app-shell { max-width: 1200px; }

/* ── 4. Navbar ──────────────────────────────────────── */
.navbar {
    background: #fff !important;
    border-bottom: 1px solid var(--dk-border) !important;
    box-shadow: 0 2px 8px rgba(75, 46, 31, .07) !important;
}

.navbar-brand {
    color: var(--dk-primary-dark) !important;
    font-size: 1.1rem;
    font-weight: 800;
    letter-spacing: -.01em;
}

.navbar-toggler {
    border-color: var(--dk-border) !important;
    color: var(--dk-primary) !important;
}

.navbar-toggler:focus {
    box-shadow: 0 0 0 .2rem rgba(122, 74, 42, .15) !important;
}

/* ── 5. Offcanvas Menu ──────────────────────────────── */
.offcanvas-header {
    background: var(--dk-primary-dark);
    color: #fff;
    border-bottom: 1px solid rgba(255,255,255,.12) !important;
}

.offcanvas-title { color: #fff !important; font-weight: 700; }

.offcanvas-header .text-muted { color: rgba(255,255,255,.6) !important; }

.offcanvas-header .btn-close {
    filter: invert(1) brightness(1.8);
    opacity: .8;
}

.menu-section { margin-bottom: 1.1rem; }

.menu-section-title {
    color: var(--dk-muted);
    font-size: .75rem;
    font-weight: 800;
    letter-spacing: .05em;
    margin-bottom: .35rem;
    text-transform: uppercase;
}

.menu-link {
    align-items: center;
    border-radius: var(--dk-radius-sm);
    color: var(--dk-ink);
    display: flex;
    min-height: 44px;
    padding: .5rem .75rem;
    text-decoration: none;
    transition: background .12s, color .12s;
}

.menu-link:focus, .menu-link:hover {
    background: var(--dk-bg);
    color: var(--dk-primary);
    text-decoration: none;
}

.menu-link-disabled { color: #b0a09a; }

.user-pill {
    align-items: start;
    background: var(--dk-bg);
    border: 1px solid var(--dk-border);
    border-radius: var(--dk-radius-sm);
    display: flex;
    flex-direction: column;
    padding: .65rem .75rem;
}

.user-pill span { font-weight: 700; line-height: 1.2; }
.user-pill small { color: var(--dk-muted); }

/* ── 6. Page / Section Headers ──────────────────────── */
.page-header,
.section-header {
    align-items: start;
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    justify-content: space-between;
}

.section-header { margin-bottom: 1rem; }

.page-header h1,
.page-header .h4 {
    color: var(--dk-primary-dark);
    font-weight: 700;
}

/* ── 7. Panels & Cards ──────────────────────────────── */
.panel {
    background: var(--dk-panel);
    border: 1px solid var(--dk-border);
    border-radius: var(--dk-radius);
    box-shadow: var(--dk-shadow);
    padding: 1rem;
}

.quick-card {
    background: var(--dk-panel);
    border: 1px solid var(--dk-border);
    border-radius: var(--dk-radius);
    box-shadow: var(--dk-shadow);
    color: inherit;
    display: block;
    min-height: 100px;
    padding: 1rem;
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s, transform .1s;
}

.quick-card:focus, .quick-card:hover {
    border-color: var(--dk-secondary);
    box-shadow: var(--dk-shadow-md);
    color: var(--dk-primary-dark);
    transform: translateY(-1px);
    text-decoration: none;
}

.quick-card-title {
    color: var(--dk-muted);
    display: block;
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .04em;
    margin-bottom: .35rem;
    text-transform: uppercase;
}

.quick-card-text {
    color: var(--dk-muted);
    display: block;
    font-size: .85rem;
    margin-top: .25rem;
}

.quick-card strong { color: var(--dk-primary-dark); }

.quick-card-primary {
    background: var(--dk-primary);
    border-color: var(--dk-primary);
    color: #fff;
}

.quick-card-primary .quick-card-title { color: rgba(255,255,255,.72); }
.quick-card-primary .quick-card-text  { color: rgba(255,255,255,.72); }
.quick-card-primary strong { color: #fff; }

.quick-card-primary:focus, .quick-card-primary:hover {
    background: var(--dk-primary-dark);
    border-color: var(--dk-primary-dark);
    color: #fff;
}

.data-card {
    background: var(--dk-panel);
    border: 1px solid var(--dk-border);
    border-radius: var(--dk-radius-sm);
    overflow-wrap: anywhere;
    padding: .85rem;
    transition: border-color .12s, box-shadow .12s;
}

a.data-card:hover, a.data-card:focus {
    border-color: var(--dk-secondary);
    box-shadow: var(--dk-shadow);
    color: inherit;
    text-decoration: none;
}

.mobile-card-list { display: grid; gap: .6rem; }

.customer-card { overflow-wrap: anywhere; }

.info-box {
    background: var(--dk-bg);
    border: 1px solid var(--dk-border);
    border-radius: var(--dk-radius-sm);
    padding: 1rem;
}

.summary-box {
    background: var(--dk-bg);
    border: 1px solid var(--dk-border);
    border-radius: var(--dk-radius-sm);
    min-height: 52px;
    padding: .65rem .85rem;
}
.summary-box-danger {
    background: var(--dk-danger-bg);
    border-color: var(--dk-danger);
    color: var(--dk-danger);
}
.summary-box-warning {
    background: var(--dk-warning-bg);
    border-color: var(--dk-warning);
    color: var(--dk-warning);
}

.line-total-box {
    background: var(--dk-bg);
    border: 1px solid var(--dk-border);
    border-radius: var(--dk-radius-sm);
    min-height: 44px;
    padding: .6rem .75rem;
}

.home-panel { max-width: 760px; }

/* ── 8. Buttons ─────────────────────────────────────── */
.touch-btn { min-height: 44px; }

.form-control, .form-select { min-height: 44px; }

.btn { border-radius: var(--dk-radius-sm); font-weight: 600; }

/* Primary (brand brown) */
.btn-primary {
    --bs-btn-bg:                 var(--dk-primary);
    --bs-btn-border-color:       var(--dk-primary);
    --bs-btn-hover-bg:           var(--dk-primary-dark);
    --bs-btn-hover-border-color: var(--dk-primary-dark);
    --bs-btn-active-bg:          var(--dk-primary-dark);
    --bs-btn-focus-shadow-rgb:   122, 74, 42;
    color: #fff !important;
}

/* Outline Primary */
.btn-outline-primary {
    --bs-btn-color:              var(--dk-primary);
    --bs-btn-border-color:       var(--dk-primary);
    --bs-btn-hover-bg:           var(--dk-primary);
    --bs-btn-hover-border-color: var(--dk-primary);
    --bs-btn-hover-color:        #fff;
    --bs-btn-active-bg:          var(--dk-primary-dark);
    --bs-btn-focus-shadow-rgb:   122, 74, 42;
}

/* Outline Secondary — warm neutral */
.btn-outline-secondary {
    --bs-btn-color:              var(--dk-muted);
    --bs-btn-border-color:       var(--dk-border);
    --bs-btn-hover-bg:           var(--dk-bg);
    --bs-btn-hover-border-color: var(--dk-secondary);
    --bs-btn-hover-color:        var(--dk-primary-dark);
    --bs-btn-active-bg:          var(--dk-bg);
}

/* Success */
.btn-outline-success {
    --bs-btn-color:              var(--dk-success);
    --bs-btn-border-color:       var(--dk-success);
    --bs-btn-hover-bg:           var(--dk-success);
    --bs-btn-hover-color:        #fff;
}

.btn-success {
    --bs-btn-bg:                 var(--dk-success);
    --bs-btn-border-color:       var(--dk-success);
    --bs-btn-hover-bg:           #155c30;
}

/* Danger */
.btn-danger {
    --bs-btn-bg:                 var(--dk-danger);
    --bs-btn-border-color:       var(--dk-danger);
    --bs-btn-hover-bg:           #7a1410;
    --bs-btn-hover-border-color: #7a1410;
}

.btn-outline-danger {
    --bs-btn-color:              var(--dk-danger);
    --bs-btn-border-color:       var(--dk-danger);
    --bs-btn-hover-bg:           var(--dk-danger);
    --bs-btn-hover-color:        #fff;
}

/* Warning */
.btn-warning {
    --bs-btn-bg:                 var(--dk-warning-bg);
    --bs-btn-border-color:       #d4890f;
    --bs-btn-color:              var(--dk-warning);
    --bs-btn-hover-bg:           #f5dfa0;
}

.btn-outline-warning {
    --bs-btn-color:              var(--dk-warning);
    --bs-btn-border-color:       #c07810;
    --bs-btn-hover-bg:           var(--dk-warning-bg);
    --bs-btn-hover-color:        var(--dk-warning);
    --bs-btn-hover-border-color: #c07810;
}

/* Light */
.btn-light {
    --bs-btn-bg:                 var(--dk-bg);
    --bs-btn-border-color:       var(--dk-border);
    --bs-btn-color:              var(--dk-ink);
    --bs-btn-hover-bg:           #ede5da;
    --bs-btn-hover-border-color: var(--dk-secondary);
}

/* Table action buttons */
.table .btn-sm, .btn-sm {
    font-size: .8rem;
    min-height: 30px;
    padding: .25rem .65rem;
}

/* ── 9. Forms ───────────────────────────────────────── */
.form-control,
.form-select {
    background-color: #fff;
    border-color: var(--dk-border);
    border-radius: var(--dk-radius-sm);
    color: var(--dk-ink);
}

.form-control:focus, .form-select:focus {
    border-color: var(--dk-secondary);
    box-shadow: 0 0 0 .2rem rgba(185, 133, 90, .22);
    background-color: #fff;
}

.form-control::placeholder { color: #b0a09a; }

.form-label {
    color: var(--dk-ink);
    font-weight: 600;
    margin-bottom: .3rem;
}

.form-label-sm { font-size: .82rem; }

.form-check-input:checked {
    background-color: var(--dk-primary);
    border-color: var(--dk-primary);
}

.form-check-input:focus {
    border-color: var(--dk-secondary);
    box-shadow: 0 0 0 .2rem rgba(185, 133, 90, .22);
}

.input-group-text {
    background: var(--dk-bg);
    border-color: var(--dk-border);
    color: var(--dk-muted);
}

.form-text { color: var(--dk-muted); }

/* ── 10. Tables ─────────────────────────────────────── */
.table {
    --bs-table-striped-bg: rgba(247, 241, 234, .6);
    --bs-table-hover-bg:   rgba(185, 133, 90, .06);
    --bs-border-color:     var(--dk-border);
    color: var(--dk-ink);
}

.table > thead {
    background: var(--dk-bg);
    color: var(--dk-muted);
    font-size: .82rem;
    font-weight: 700;
}

.table > thead th {
    border-bottom-color: var(--dk-border);
    padding: .65rem .75rem;
}

.table-light {
    --bs-table-bg: var(--dk-bg);
    color: var(--dk-muted);
    font-weight: 600;
}

/* ── 11. Status Badges ──────────────────────────────── */

/* Custom warm status badges (order_status_badge / payment_status_badge) */
.badge-dk-draft              { background: #e8e0d8; color: #5a4535; }
.badge-dk-pending_confirmation { background: var(--dk-warning-bg); color: var(--dk-warning); }
.badge-dk-confirmed          { background: var(--dk-success-bg); color: var(--dk-success); }
.badge-dk-in_production      { background: #d4e0f4; color: #1d3c72; }
.badge-dk-ready              { background: #c6ebda; color: #145030; }
.badge-dk-with_driver        { background: #ffe2c0; color: #7a3a05; }
.badge-dk-delivered          { background: #e8e4e0; color: #3d3028; }
.badge-dk-cancelled          { background: var(--dk-danger-bg); color: var(--dk-danger); }

/* Payment */
.badge-dk-unpaid   { background: var(--dk-danger-bg);  color: var(--dk-danger); }
.badge-dk-partial  { background: var(--dk-warning-bg); color: var(--dk-warning); }
.badge-dk-paid     { background: var(--dk-success-bg); color: var(--dk-success); }

/* Generic Bootstrap badge overrides — calmer tones */
.text-bg-warning { background-color: var(--dk-warning-bg) !important; color: var(--dk-warning) !important; }
.text-bg-danger  { background-color: var(--dk-danger-bg)  !important; color: var(--dk-danger)  !important; }
.text-bg-success { background-color: var(--dk-success-bg) !important; color: var(--dk-success) !important; }
.text-bg-info    { background-color: var(--dk-info-bg)    !important; color: var(--dk-info)    !important; }
.text-bg-primary { background-color: var(--dk-primary)    !important; color: #fff              !important; }

/* ── 12. Alerts ─────────────────────────────────────── */
.alert-light {
    background: var(--dk-bg);
    border-color: var(--dk-border);
    color: var(--dk-muted);
}

.alert-success {
    background: var(--dk-success-bg);
    border-color: #a8d9bf;
    color: var(--dk-success);
}

.alert-danger {
    background: var(--dk-danger-bg);
    border-color: #f5b8b5;
    color: var(--dk-danger);
}

.alert-warning {
    background: var(--dk-warning-bg);
    border-color: #f0d090;
    color: var(--dk-warning);
}

.alert-info {
    background: var(--dk-info-bg);
    border-color: #a8c8e8;
    color: var(--dk-info);
}

/* ── 13. Pagination ─────────────────────────────────── */
.page-link {
    color: var(--dk-primary);
    border-color: var(--dk-border);
    background: var(--dk-panel);
}

.page-link:hover {
    background: var(--dk-bg);
    border-color: var(--dk-secondary);
    color: var(--dk-primary-dark);
}

.page-item.active .page-link {
    background-color: var(--dk-primary);
    border-color: var(--dk-primary);
    color: #fff;
}

.page-item.disabled .page-link {
    background: var(--dk-bg);
    border-color: var(--dk-border);
    color: var(--dk-muted);
}

/* ── 14. Login ──────────────────────────────────────── */
.login-wrapper {
    align-items: center;
    display: flex;
    justify-content: center;
    min-height: 72vh;
    padding: 1.5rem 0;
}

.login-card {
    max-width: 430px;
    padding: 1.75rem 2rem;
    width: 100%;
}

.login-card h1 {
    color: var(--dk-primary-dark);
    font-weight: 700;
    margin-bottom: 1.25rem;
}

/* ── 15. Product Picker ─────────────────────────────── */
.cat-tabs {
    display: flex;
    flex-wrap: nowrap;
    gap: .4rem;
    overflow-x: auto;
    padding-bottom: .4rem;
    scrollbar-width: none;
}

.cat-tabs::-webkit-scrollbar { display: none; }

.cat-tab {
    background: var(--dk-panel);
    border: 1px solid var(--dk-border);
    border-radius: 20px;
    color: var(--dk-ink);
    cursor: pointer;
    flex-shrink: 0;
    font-size: .82rem;
    font-weight: 600;
    min-height: 36px;
    padding: .3rem .9rem;
    transition: background .12s, border-color .12s;
    white-space: nowrap;
}

.cat-tab:hover { border-color: var(--dk-secondary); }

.cat-tab.active {
    background: var(--dk-primary);
    border-color: var(--dk-primary);
    color: #fff;
}

.product-cards-grid {
    display: grid;
    gap: .5rem;
    grid-template-columns: repeat(2, 1fr);
    margin-top: .6rem;
    max-height: 380px;
    overflow-y: auto;
    padding-bottom: .25rem;
}

@media (min-width: 576px) { .product-cards-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 992px) { .product-cards-grid { grid-template-columns: repeat(4, 1fr); } }

.product-card {
    background: var(--dk-panel);
    border: 1px solid var(--dk-border);
    border-radius: var(--dk-radius-sm);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    min-width: 0;
    padding: .6rem;
    transition: border-color .12s, box-shadow .12s;
}

.product-card:hover {
    border-color: var(--dk-secondary);
    box-shadow: var(--dk-shadow);
}

.product-card-name {
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    display: -webkit-box;
    font-size: .82rem;
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: .2rem;
    overflow: hidden;
}

.product-card-price { color: var(--dk-primary); font-size: .8rem; font-weight: 700; }
.product-card-meta  { color: var(--dk-muted); font-size: .72rem; margin-bottom: .3rem; }

.cart-item-row { background: var(--dk-bg); }

.cart-price-warn {
    background: #fffbf0;
    border-color: #c07810 !important;
}

/* ── 16. Order Timeline ─────────────────────────────── */
.status-timeline {
    list-style: none;
    margin: 0;
    padding: 0;
    position: relative;
}

.status-timeline::before {
    background: var(--dk-border);
    bottom: 0;
    content: '';
    position: absolute;
    right: 9px;
    top: 0;
    width: 2px;
}

.status-timeline-item {
    padding-bottom: .9rem;
    padding-right: 32px;
    position: relative;
}

.status-timeline-item:last-child { padding-bottom: 0; }

.status-timeline-dot {
    background: #fff;
    border: 2px solid var(--dk-border);
    border-radius: 50%;
    height: 16px;
    position: absolute;
    right: 2px;
    top: 2px;
    width: 16px;
}

.status-timeline-item.tl-done .status-timeline-dot {
    background: var(--dk-success);
    border-color: var(--dk-success);
}

.status-timeline-item.tl-active .status-timeline-dot {
    background: var(--dk-primary);
    border-color: var(--dk-primary);
    box-shadow: 0 0 0 3px rgba(122, 74, 42, .18);
}

.status-timeline-item.tl-cancelled .status-timeline-dot {
    background: var(--dk-danger);
    border-color: var(--dk-danger);
}

.status-timeline-item.tl-pending { opacity: .4; }

.order-status-header { align-items: center; display: flex; flex-wrap: wrap; gap: .5rem; }

.status-actions .btn { font-size: 1rem; font-weight: 700; min-height: 52px; }

/* ── 17. CRM & Customers ────────────────────────────── */
.customer-meta,
.data-meta {
    display: grid;
    gap: .35rem .75rem;
    grid-template-columns: minmax(74px, auto) 1fr;
}

.customer-meta dt, .data-meta dt { color: var(--dk-muted); font-weight: 600; }
.customer-meta dd, .data-meta dd { margin: 0; }

.customer-form, .data-form { max-width: 900px; }

.customer-selected-card {
    background: var(--dk-success-bg);
    border: 1.5px solid var(--dk-success);
    border-radius: var(--dk-radius-sm);
    padding: .85rem 1rem;
}

.customer-search-result {
    border-bottom: 1px solid var(--dk-border);
    cursor: pointer;
    padding: .65rem .75rem;
}

.customer-search-result:last-child { border-bottom: 0; }

.customer-search-result:hover, .customer-search-result:focus {
    background: var(--dk-bg);
    outline: none;
}

/* ── 18. Inventory ──────────────────────────────────── */
.low-stock {
    background: #fffdf5;
    border-color: #c07810;
}

/* ── 19. Production Board ───────────────────────────── */
.production-board { display: grid; gap: .75rem; }
.production-task-card { background: var(--dk-panel); }

/* ── 20. Permissions ────────────────────────────────── */
.permission-option {
    align-items: flex-start;
    border: 1px solid var(--dk-border);
    border-radius: var(--dk-radius-sm);
    display: flex;
    gap: .65rem;
    min-height: 88px;
    padding: .75rem;
}

.permission-option span { display: grid; gap: .2rem; }
.permission-option small { color: var(--dk-muted); }

.permission-option code {
    color: var(--dk-primary);
    direction: ltr;
    display: inline-block;
    font-size: .78rem;
    text-align: left;
}

/* ── 21. Invoice & Print ────────────────────────────── */
.invoice-text {
    direction: rtl;
    font-family: Tahoma, Arial, sans-serif;
    min-height: 360px;
}

.print-invoice, .print-plan {
    max-width: 900px;
    margin-inline: auto;
}

.invoice-totals { max-width: 340px; }

.invoice-footer {
    border-top: 1px solid var(--dk-border);
    padding-top: .75rem;
}

/* ── 22. Mobile Quick Actions ───────────────────────── */
.mobile-quick-actions {
    background: #fff;
    border-top: 1px solid var(--dk-border);
    bottom: 0;
    box-shadow: 0 -2px 12px rgba(75, 46, 31, .10);
    display: grid;
    gap: 0;
    grid-template-columns: repeat(4, 1fr);
    left: 0;
    position: fixed;
    right: 0;
    z-index: 1030;
}

.mobile-quick-actions a {
    align-items: center;
    color: var(--dk-ink);
    display: flex;
    font-size: .8rem;
    font-weight: 700;
    justify-content: center;
    min-height: 56px;
    padding: .4rem .25rem;
    text-align: center;
    text-decoration: none;
}

.mobile-quick-actions a:focus, .mobile-quick-actions a:hover {
    background: var(--dk-bg);
    color: var(--dk-primary);
    text-decoration: none;
}

/* ── 23. Footer ─────────────────────────────────────── */
footer {
    background: var(--dk-panel) !important;
    border-top-color: var(--dk-border) !important;
    color: var(--dk-muted);
}

/* ── 24. Responsive ─────────────────────────────────── */
@media (min-width: 992px) {
    .production-board {
        grid-template-columns: repeat(4, minmax(220px, 1fr));
        overflow-x: auto;
        padding-bottom: .5rem;
    }

    .production-column { min-width: 220px; }
}

@media (max-width: 991.98px) {
    body { padding-bottom: 64px; }

    .page-header .btn,
    .section-header .btn {
        width: 100%;
    }
}

/* ── 25. Print ──────────────────────────────────────── */
.print-only { display: none !important; }

@media print {
    /* ─ صفحة A4 ─ */
    @page { size: A4 portrait; margin: 1.5cm; }

    /* ─ إخفاء كل شيء، وإظهار print-area فقط ─ */
    body * { visibility: hidden !important; }
    .print-area,
    .print-area * { visibility: visible !important; }
    .print-area {
        position: absolute;
        top: 0;
        right: 0;
        left: 0;
        width: 100%;
        direction: rtl;
        padding: 0;
        background: #fff !important;
    }

    /* ─ أساسيات ─ */
    body { background: #fff !important; color: #111 !important; }

    /* ─ عناصر الطباعة فقط ─ */
    .print-only { display: block !important; visibility: visible !important; }

    /* ─ إخفاء في الطباعة ─ */
    .no-print { display: none !important; visibility: hidden !important; }
    .print-hide { display: none !important; }
    .print-show { display: block !important; }

    /* ─ Panel ─ */
    .print-area .panel {
        border: 1px solid #ccc !important;
        box-shadow: none !important;
        background: #fff !important;
        padding: .5rem .75rem !important;
        margin-bottom: .75rem !important;
        break-inside: avoid;
    }

    /* ─ رأس الطباعة ─ */
    .print-header {
        border-bottom: 2px solid #333;
        padding-bottom: .5rem;
        margin-bottom: 1rem;
        text-align: center;
    }

    /* ─ الجداول ─ */
    .print-area .table-responsive { overflow: visible !important; }
    .print-area .table {
        border-collapse: collapse !important;
        width: 100% !important;
        font-size: 10pt !important;
    }
    .print-area .table th,
    .print-area .table td {
        border: 1px solid #999 !important;
        padding: 4px 6px !important;
    }
    .print-area .table-light th,
    .print-area .table-light td {
        background: #f2f2f2 !important;
        print-color-adjust: exact;
        -webkit-print-color-adjust: exact;
    }

    /* ─ ملخص ─ */
    .print-area .summary-box {
        border: 1px solid #ccc !important;
        box-shadow: none !important;
        background: #fff !important;
        font-size: 10pt !important;
        padding: .3rem .5rem !important;
        break-inside: avoid;
    }

    /* ─ روابط ─ */
    .print-area a { color: #111 !important; text-decoration: none !important; }

    /* ─ Bootstrap grid في الطباعة ─ */
    .print-area .row { display: flex !important; flex-wrap: wrap !important; }
    .print-area .col-6   { flex: 0 0 50% !important; max-width: 50% !important; }
    .print-area .col-md-3 { flex: 0 0 25% !important; max-width: 25% !important; }
    .print-area .col-lg-6,
    .print-area .col-12.col-lg-6 { flex: 0 0 50% !important; max-width: 50% !important; }
    .print-area .col-12 { flex: 0 0 100% !important; max-width: 100% !important; }

    /* ─ صفحات الفواتير (موجودة سابقاً) ─ */
    .print-invoice, .print-plan { padding: 0; max-width: none; }
    .invoice-table th, .invoice-table td { border-color: #999 !important; }
    .invoice-totals { margin-top: 1rem; max-width: 320px; }
    .purchase-category { break-inside: avoid; page-break-inside: avoid; }
}
