/* ============================================================
   JNR AGRO — Main Stylesheet  v2
   Light mode default | Dark via [data-theme="dark"]
   ============================================================ */

:root {
    --bg:          #f0f2f5;
    --surface:     #ffffff;
    --surface2:    #f7f8fa;
    --surface3:    #eef0f3;
    --border:      #e2e5ea;
    --border2:     #d0d5dd;
    --accent:      #e07b00;
    --accent2:     #c96e00;
    --text:        #1a1d23;
    --text2:       #4b5563;
    --text3:       #9ca3af;
    --green:       #16a34a;
    --red:         #dc2626;
    --blue:        #2563eb;
    --purple:      #7c3aed;
    --wa:          #25D366;
    --radius:      10px;
    --radius-lg:   16px;
    --shadow:      0 2px 10px rgba(0,0,0,0.07);
    --shadow-md:   0 6px 28px rgba(0,0,0,0.13);
    --sidebar-w:   240px;
    --topbar-h:    60px;
    --bnav-h:      62px;
    --font:        "Inter", sans-serif;
}
[data-theme="dark"] {
    --bg:       #0f1117;
    --surface:  #1a1d26;
    --surface2: #22263a;
    --surface3: #2a2e3f;
    --border:   #2f3347;
    --border2:  #3d4257;
    --accent:   #f0a500;
    --accent2:  #e8941a;
    --text:     #e8eaf0;
    --text2:    #9aa3b0;
    --text3:    #5c6470;
    --green:    #22c55e;
    --red:      #ef4444;
    --blue:     #3b82f6;
    --shadow:   0 4px 24px rgba(0,0,0,0.4);
    --shadow-md:0 8px 40px rgba(0,0,0,0.5);
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;
     display:flex;overflow-x:hidden;line-height:1.6;transition:background .2s,color .2s}

/* SIDEBAR */
.sidebar{width:var(--sidebar-w);min-height:100vh;background:var(--surface);
  border-right:1px solid var(--border);display:flex;flex-direction:column;
  position:fixed;left:0;top:0;bottom:0;z-index:200;
  transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto}
.sidebar-brand{padding:22px 20px 18px;border-bottom:1px solid var(--border);flex-shrink:0}
.sidebar-brand h1{font-size:1.2rem;font-weight:800;color:var(--accent);letter-spacing:-.5px}
.sidebar-brand p{font-size:.73rem;color:var(--text3);margin-top:3px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.sidebar-nav{flex:1;padding:14px 10px;overflow-y:auto}
.nav-section{margin-bottom:20px}
.nav-label{font-size:.67rem;font-weight:700;color:var(--text3);text-transform:uppercase;
  letter-spacing:1.5px;padding:0 10px;margin-bottom:5px;font-family:inherit;display:block}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;
  border-radius:var(--radius);color:var(--text2);text-decoration:none;
  font-size:.9rem;font-weight:500;transition:all .15s;margin-bottom:2px;white-space:nowrap}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:rgba(224,123,0,.1);color:var(--accent);font-weight:600}
[data-theme="dark"] .nav-item.active{background:rgba(240,165,0,.15)}
.nav-item i{width:18px;text-align:center;font-size:.85rem;flex-shrink:0}
.sidebar-footer{padding:14px 20px;border-top:1px solid var(--border);font-size:.73rem;color:var(--text3);flex-shrink:0}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199;backdrop-filter:blur(2px)}
.sidebar-overlay.open{display:block}

/* MAIN */
.main{margin-left:var(--sidebar-w);flex:1;min-height:100vh;display:flex;flex-direction:column;min-width:0;overflow-x:hidden}

/* TOPBAR */
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 22px;
  height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:90;gap:12px}
.topbar-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}
.topbar-title{font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.hamburger{display:none;background:none;border:none;color:var(--text);font-size:1.2rem;
  cursor:pointer;padding:6px 8px;border-radius:8px;transition:background .15s;flex-shrink:0}
.hamburger:hover{background:var(--surface2)}
.theme-toggle{background:var(--surface2);border:1px solid var(--border2);color:var(--text2);
  cursor:pointer;padding:7px 10px;border-radius:8px;font-size:1rem;
  display:flex;align-items:center;transition:all .15s;flex-shrink:0}
.theme-toggle:hover{background:var(--surface3);color:var(--text)}

/* CONTENT */
.content{padding:22px 20px;flex:1;min-width:0;overflow-x:hidden}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow)}
.card-header{display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border);gap:10px;flex-wrap:wrap}
.card-title{font-size:.95rem;font-weight:700;color:var(--text)}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px;margin-bottom:18px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:15px 17px;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.stat-card.accent{border-left:4px solid var(--accent)}
.stat-card.red{border-left:4px solid var(--red)}
.stat-card.green{border-left:4px solid var(--green)}
.stat-card.blue{border-left:4px solid var(--blue)}
.stat-label{font-size:.73rem;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.stat-value{font-size:1.45rem;font-weight:800;line-height:1.1;margin-bottom:3px}
.stat-sub{font-size:.73rem;color:var(--text3)}
.stat-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:1.9rem;color:var(--border2);opacity:.5}
.text-accent{color:var(--accent)}

/* LAYOUT GRID CLASSES (named — overridden by media queries) */
.grid-main  {display:grid;grid-template-columns:1fr 320px;gap:18px}
.grid-halves{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid-inv   {display:grid;grid-template-columns:1fr auto;gap:18px;align-items:start}
.grid-totals{display:grid;grid-template-columns:1fr 290px;gap:18px;align-items:start}
.grid-bill  {display:grid;grid-template-columns:1fr 310px;gap:18px;align-items:start}
.grid-prod  {display:grid;grid-template-columns:1fr 270px;gap:18px;align-items:start}
.grid-2sm   {display:grid;grid-template-columns:1fr 1fr;gap:9px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border-radius:var(--radius);
  border:none;cursor:pointer;font-family:var(--font);font-size:.87rem;font-weight:600;
  text-decoration:none;transition:all .15s;white-space:nowrap;line-height:1.4}
.btn:active{transform:scale(.97)}
.btn-primary  {background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent2)}
.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border2)}
.btn-secondary:hover{background:var(--surface3)}
.btn-danger   {background:rgba(220,38,38,.1);color:var(--red);border:1px solid rgba(220,38,38,.25)}
.btn-danger:hover{background:rgba(220,38,38,.18)}
.btn-success  {background:rgba(22,163,74,.1);color:var(--green);border:1px solid rgba(22,163,74,.25)}
.btn-success:hover{background:rgba(22,163,74,.18)}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{background:#1ebe5d}
.btn-info{background:rgba(37,99,235,.1);color:var(--blue);border:1px solid rgba(37,99,235,.25)}
.btn-info:hover{background:rgba(37,99,235,.18)}
.btn-sm{padding:5px 10px;font-size:.78rem}
.btn-lg{padding:11px 22px;font-size:.96rem}
.btn-icon{padding:7px;min-width:32px;justify-content:center}
.btn-block{width:100%;justify-content:center}
[data-theme="dark"] .btn-danger {background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3)}
[data-theme="dark"] .btn-success{background:rgba(34,197,94,.15);border-color:rgba(34,197,94,.3)}
[data-theme="dark"] .btn-info   {background:rgba(59,130,246,.15);border-color:rgba(59,130,246,.3)}
.btn-wa-prominent{background:linear-gradient(135deg,#25D366,#1ebe5d);color:#fff;
  font-size:.93rem;padding:10px 18px;border-radius:var(--radius);
  box-shadow:0 4px 14px rgba(37,211,102,.25);border:none}
.btn-wa-prominent:hover{background:linear-gradient(135deg,#1ebe5d,#17a84f);transform:translateY(-1px)}

/* FORMS */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:13px}
.form-group{display:flex;flex-direction:column;gap:5px}
.form-group.full{grid-column:1/-1}
label{font-size:.81rem;color:var(--text2);font-weight:600;letter-spacing:.2px}
label span.req{color:var(--red)}
input,select,textarea{background:var(--surface);border:1.5px solid var(--border2);
  border-radius:var(--radius);padding:9px 12px;color:var(--text);font-size:.9rem;
  font-family:var(--font);transition:border-color .15s,box-shadow .15s;
  width:100%;-webkit-appearance:none;appearance:none}
[data-theme="dark"] input,[data-theme="dark"] select,[data-theme="dark"] textarea{background:var(--surface2);border-color:var(--border2)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(224,123,0,.12)}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%236b7280' d='M6 8L0 0h12z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
select option{background:var(--surface);color:var(--text)}
textarea{resize:vertical;min-height:70px}
.input-group{display:flex}
.input-group input{border-radius:var(--radius) 0 0 var(--radius)}
.input-addon{background:var(--surface2);border:1.5px solid var(--border2);border-left:none;
  padding:9px 12px;border-radius:0 var(--radius) var(--radius) 0;
  color:var(--text3);font-size:.8rem;white-space:nowrap;display:flex;align-items:center}

/* TABLES */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%;max-width:100%}
table{width:100%;border-collapse:collapse;font-size:.87rem}
th{background:var(--surface2);padding:9px 11px;text-align:left;font-size:.7rem;
  font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);
  font-family:inherit;border-bottom:2px solid var(--border);white-space:nowrap}
td{padding:9px 11px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--surface2)}
.table-empty{text-align:center;padding:44px;color:var(--text3);font-size:.92rem}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:.71rem;font-weight:700;white-space:nowrap}
.badge-green {background:rgba(22,163,74,.12);color:var(--green)}
.badge-red   {background:rgba(220,38,38,.12);color:var(--red)}
.badge-yellow{background:rgba(224,123,0,.12);color:var(--accent)}
.badge-blue  {background:rgba(37,99,235,.12);color:var(--blue)}
.badge-gray  {background:var(--surface3);color:var(--text3)}
.badge-purple{background:rgba(124,58,237,.12);color:var(--purple)}
.badge-teal  {background:rgba(13,148,136,.12);color:#0d9488}
[data-theme="dark"] .badge-green {background:rgba(34,197,94,.15)}
[data-theme="dark"] .badge-red   {background:rgba(239,68,68,.15)}
[data-theme="dark"] .badge-yellow{background:rgba(240,165,0,.15)}
[data-theme="dark"] .badge-blue  {background:rgba(59,130,246,.15)}

/* ALERTS */
.alert{padding:11px 15px;border-radius:var(--radius);font-size:.87rem;margin-bottom:15px;
  display:flex;align-items:flex-start;gap:9px;line-height:1.5}
.alert i{margin-top:2px;flex-shrink:0}
.alert-success{background:rgba(22,163,74,.08); border:1px solid rgba(22,163,74,.25);color:var(--green)}
.alert-error  {background:rgba(220,38,38,.08); border:1px solid rgba(220,38,38,.25);color:var(--red)}
.alert-info   {background:rgba(37,99,235,.08); border:1px solid rgba(37,99,235,.25);color:var(--blue)}
.alert-warning{background:rgba(224,123,0,.08); border:1px solid rgba(224,123,0,.25);color:var(--accent)}

/* MODALS */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);
  z-index:999;align-items:center;justify-content:center;padding:14px;backdrop-filter:blur(3px)}
.modal-backdrop.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  width:100%;max-width:580px;max-height:90vh;display:flex;flex-direction:column;
  box-shadow:var(--shadow-md);animation:modalIn .22s ease}
@keyframes modalIn{from{transform:scale(.95) translateY(-10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.modal-header{padding:15px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-title{font-size:.98rem;font-weight:700}
.modal-close{background:var(--surface2);border:1px solid var(--border);color:var(--text2);
  cursor:pointer;font-size:.95rem;padding:5px 9px;border-radius:8px;
  transition:all .15s;display:flex;align-items:center}
.modal-close:hover{background:var(--red);color:#fff;border-color:var(--red)}
.modal-body{padding:18px;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}
.modal-footer{padding:13px 18px;border-top:1px solid var(--border);display:flex;gap:9px;justify-content:flex-end;flex-shrink:0}

/* PAGE HEADER */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:10px;flex-wrap:wrap}
.page-title{font-size:1.35rem;font-weight:800;line-height:1.2}
.page-title span{color:var(--accent)}

/* BOTTOM NAV */
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;
  height:var(--bnav-h);background:var(--surface);border-top:2px solid var(--border);
  z-index:150;box-shadow:0 -4px 18px rgba(0,0,0,.1)}
.bottom-nav-items{display:grid;grid-template-columns:repeat(5,1fr);height:100%;align-items:center}
.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;text-decoration:none;color:var(--text3);font-size:.61rem;font-weight:600;
  padding:5px 2px;transition:color .15s;position:relative}
.bottom-nav-item i{font-size:1.1rem}
.bottom-nav-item.active{color:var(--accent)}
.bottom-nav-item.active::before{content:"";position:absolute;top:0;left:20%;right:20%;
  height:2px;background:var(--accent);border-radius:0 0 4px 4px}
.bn-center{background:var(--accent);color:#fff !important;border-radius:50%;
  width:44px;height:44px;margin:0 auto;padding:0;font-size:0 !important}
.bn-center i{font-size:1.15rem !important;color:#fff}
.bn-center:hover{background:var(--accent2)}
.bn-center::before{display:none !important}

/* INVOICE WA BAR */
.invoice-wa-bar{background:rgba(37,211,102,.06);border:1px solid rgba(37,211,102,.2);
  border-radius:var(--radius-lg);padding:13px 17px;display:flex;align-items:center;
  justify-content:space-between;gap:13px;margin-bottom:16px;flex-wrap:wrap}
.invoice-wa-bar-text h4{font-size:.93rem;font-weight:700;color:var(--wa);margin-bottom:3px}
.invoice-wa-bar-text p{font-size:.77rem;color:var(--text3)}

/* GST TABLE */
.inv-gst-table{width:100%;border-collapse:collapse;font-size:.83rem}
.inv-gst-table th{background:var(--surface2);padding:8px 11px;text-align:center;
  font-size:.75rem;border:1px solid var(--border2);color:var(--text2);font-weight:700;text-transform:none;letter-spacing:0}
.inv-gst-table td{padding:8px 11px;text-align:center;border:1px solid var(--border2);color:var(--text)}

/* LOGIN */
.login-wrapper{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:38px 34px;width:100%;max-width:420px;box-shadow:var(--shadow-md)}
.login-logo{text-align:center;margin-bottom:30px}
.login-logo h1{font-size:1.65rem;font-weight:800;color:var(--accent);letter-spacing:-.5px}
.login-logo p{font-size:.81rem;color:var(--text3);margin-top:4px}
.login-icon{width:60px;height:60px;background:rgba(224,123,0,.1);border:1px solid rgba(224,123,0,.2);
  border-radius:15px;display:flex;align-items:center;justify-content:center;margin:0 auto 15px;font-size:1.5rem;color:var(--accent)}
.login-footer{text-align:center;margin-top:22px;font-size:.73rem;color:var(--text3)}

/* UTILITIES */
.text-right{text-align:right}.text-center{text-align:center}.text-left{text-align:left}

.text-green{color:var(--green)}.text-red{color:var(--red)}.text-blue{color:var(--blue)}.text-muted{color:var(--text3)}
.text-sm{font-size:.79rem}.text-xs{font-size:.7rem}
.fw-bold{font-weight:700}.fw-600{font-weight:600}
.mt-1{margin-top:8px}.mt-2{margin-top:14px}.mt-3{margin-top:22px}
.mb-1{margin-bottom:8px}.mb-2{margin-bottom:14px}.mb-3{margin-bottom:22px}
.flex{display:flex}.flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-gap{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.flex-col{display:flex;flex-direction:column}
.divider{height:1px;background:var(--border);margin:14px 0}
.w-full{width:100%}

/* FILTER CARD */
.filter-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:13px 16px;margin-bottom:14px;box-shadow:var(--shadow)}
.filter-row{display:flex;flex-wrap:wrap;gap:9px;align-items:flex-end}

/* ============================================================
   MOBILE 768px
   ============================================================ */
@media(max-width:768px){
    .sidebar{transform:translateX(-100%)}
    .sidebar.open{transform:translateX(0)}
    .main{margin-left:0;overflow-x:hidden}
    .hamburger{display:flex;align-items:center;justify-content:center}
    .content{padding:12px 11px;padding-bottom:calc(var(--bnav-h) + 12px);overflow-x:hidden}
    .topbar{padding:0 11px}
    .topbar-title{font-size:.88rem}
    .topbar-right .btn span.btn-text{display:none}
    .bottom-nav{display:block}

    /* Page header */
    .page-header{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:14px}
    .page-title{font-size:1.1rem}

    /* Stats: 2 columns always */
    .stats-grid{grid-template-columns:repeat(2,1fr) !important;gap:8px;margin-bottom:12px}
    .stat-value{font-size:1.1rem}
    .stat-icon{display:none}
    .stat-card{padding:11px 13px}

    /* Cards */
    .card{padding:12px;border-radius:var(--radius)}
    .card-header{margin-bottom:10px;padding-bottom:10px}

    /* Forms */
    .form-grid{grid-template-columns:1fr !important;gap:9px}
    .form-group.full{grid-column:auto}
    .filter-row{flex-direction:column;gap:8px}
    .filter-row > *{width:100%}
    .filter-row > div:last-child{width:auto}

    /* Tables */
    .table-wrap{max-width:100%;overflow-x:auto}
    td,th{padding:7px 9px;font-size:.8rem}

    /* All layout grids → 1 column */
    .grid-main  {grid-template-columns:1fr !important}
    .grid-halves{grid-template-columns:1fr !important}
    .grid-inv   {grid-template-columns:1fr !important}
    .grid-totals{grid-template-columns:1fr !important}
    .grid-bill  {grid-template-columns:1fr !important}
    .grid-prod  {grid-template-columns:1fr !important}
    .grid-2sm   {grid-template-columns:1fr 1fr}

    /* Buttons */
    .flex-gap{gap:5px}
    .btn{padding:7px 11px;font-size:.82rem}
    .btn-sm{padding:5px 8px;font-size:.75rem}
    .btn-lg{padding:10px 16px;font-size:.9rem}

    /* Modals */
    .modal-backdrop{padding:8px}
    .modal{border-radius:var(--radius-lg);max-height:95vh;max-width:100%}
    .modal-body{padding:13px}
    .modal-header{padding:12px 15px}
    .modal-footer{padding:11px 15px}

    /* Invoice header */
    .inv-header-num{text-align:left !important;margin-top:12px}

    /* Challan grids */
    .inv-bottom-grid{grid-template-columns:1fr !important}
    .inv-party-transport{grid-template-columns:1fr !important}

    /* Hide cols */
    td.hide-mobile,th.hide-mobile{display:none}

    /* WA bar */
    .invoice-wa-bar{flex-direction:column;align-items:flex-start}
    .invoice-wa-bar .btn-wa-prominent{width:100%;justify-content:center}
}

@media(max-width:480px){
    html{font-size:14px}
    .login-card{padding:24px 16px}
    .topbar-right .new-bill-btn{display:none}
    td.hide-sm,th.hide-sm{display:none}
}

/* ── Order mobile cards ──────────────────────────────────────────────────── */
.orders-mobile-list { display: none; }
.order-card {
    padding: 12px 14px;
    border-bottom: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.order-card:last-child { border-bottom: none; }
.order-card--done { opacity: .6; }
.order-card-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 8px;
}
.order-card-no { font-size: .85rem; font-weight: 700; }
.order-card-by { font-size: .72rem; color: var(--text3); margin-left: 5px; }
.order-card-status { flex-shrink: 0; }
.order-card-party {
    font-size: .85rem;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
}
.order-card-phone {
    font-size: .75rem;
    color: var(--text3);
    margin-left: 4px;
}
.order-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.order-card-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    padding-top: 4px;
}

@media(max-width:768px) {
    /* Show cards, hide table */
    .orders-table-wrap { display: none !important; }
    .orders-mobile-list { display: block; }

    /* Date nav — stack on very small screens */
    .orders-date-nav { flex-wrap: wrap; gap: 8px; }

    /* Filter row full width */
    .orders-filter-row select { flex: 1; min-width: 0; }
}
/* PWA Install Banner — mobile only, hidden on desktop */
@media(min-width:769px){
    .pwa-install-banner{ display:none !important; }
}

@media print{
    .sidebar,.topbar,.no-print,.invoice-wa-bar,.bottom-nav,.sidebar-overlay{display:none !important}
    .main{margin-left:0 !important}
    body{background:#fff;color:#000;display:block;font-size:10.5pt}
    .content{padding:0;margin:0}
    .card{border:none !important;box-shadow:none !important;background:#fff !important;padding:10px !important;margin:0 !important}
    .card *{color:#000 !important}
    /* Preserve explicit background colours on table headers */
    th[style],thead tr{-webkit-print-color-adjust:exact;print-color-adjust:exact}
    /* All tables use border from inline styles — don't override */
    table{border-collapse:collapse}
    a{text-decoration:none;color:#000 !important}
    .badge{border:1px solid #999 !important}
    /* Layout grids — keep side-by-side on print */
    .inv-bottom-grid{display:grid !important;grid-template-columns:155px 1fr 210px !important;gap:18px !important}
    .inv-party-transport{display:grid !important;grid-template-columns:1fr 1fr !important;gap:0 !important}
    .grid-main,.grid-bill,.grid-totals,.grid-prod{display:block !important}
    /* tfoot row */
    tfoot tr td{-webkit-print-color-adjust:exact;print-color-adjust:exact}
    /* Show all columns on print */
    td.hide-mobile,th.hide-mobile{display:table-cell !important}
    /* Page setup */
    @page{margin:12mm 12mm 12mm 12mm;size:A4}
}
