/* ============================================================
   SpareParts Pro 2.0 — Mtindo Mkuu (style.css)
   ============================================================ */
:root {
  --primary:   #1a2744;
  --primary2:  #243459;
  --accent:    #f97316;
  --accent2:   #ea6c0a;
  --green:     #16a34a;
  --red:       #dc2626;
  --amber:     #d97706;
  --blue:      #2563eb;
  --bg:        #f1f5f9;
  --card:      #ffffff;
  --border:    #e2e8f0;
  --text:      #1e293b;
  --text2:     #64748b;
  --text3:     #94a3b8;
  --sidebar-w: 255px;
  --radius:    10px;
  --radius-sm: 6px;
  --shadow:    0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
  --shadow-lg: 0 8px 30px rgba(0,0,0,.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.55;min-height:100vh;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%}
button,input,select,textarea{font-family:inherit;font-size:inherit}

/* ── MUUNDO MKUU ─────────────────────────────────────────── */
.app{display:flex;min-height:100vh}
.kando{width:var(--sidebar-w);background:var(--primary);position:fixed;top:0;left:0;height:100vh;overflow-y:auto;z-index:200;display:flex;flex-direction:column;transition:transform .3s;box-shadow:4px 0 24px rgba(0,0,0,.18)}
.eneo-kuu{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-width:0}

/* ── SIDEBAR ─────────────────────────────────────────────── */
.kando-logo{padding:18px 16px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.08)}
.kando-logo-icon{width:38px;height:38px;background:var(--accent);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.kando-logo-text{color:#fff;font-weight:800;font-size:15px;line-height:1.2}
.kando-logo-text small{display:block;font-size:10px;color:var(--text3);font-weight:400}

/* DUKA SWITCHER — Kipengele kipya */
.duka-switcher{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08)}
.duka-switcher-kichwa{font-size:9px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px;padding:0 4px}
.duka-sasa-card{background:rgba(249,115,22,.15);border:1px solid rgba(249,115,22,.3);border-radius:8px;padding:8px 10px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:space-between;gap:8px}
.duka-sasa-card:hover{background:rgba(249,115,22,.25)}
.duka-sasa-jina{color:#fed7aa;font-weight:700;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.duka-sasa-namba{font-size:10px;color:var(--text3)}
.duka-switch-icon{color:#fed7aa;font-size:14px;flex-shrink:0}
.maduka-dropdown{background:var(--primary2);border-radius:8px;margin-top:4px;overflow:hidden;display:none}
.maduka-dropdown.wazi{display:block}
.duka-chaguo{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;transition:background .15s;color:#cbd5e1;font-size:12px;border-bottom:1px solid rgba(255,255,255,.05)}
.duka-chaguo:last-child{border-bottom:none}
.duka-chaguo:hover{background:rgba(255,255,255,.06);color:#fff}
.duka-chaguo.amechaguliwa{background:rgba(249,115,22,.2);color:#fed7aa}
.duka-chaguo-jina{flex:1;font-weight:600}
.duka-chaguo-hali{font-size:9px;padding:2px 6px;border-radius:10px;background:rgba(22,163,74,.2);color:#86efac}
.duka-chaguo-hali.inasubiri{background:rgba(217,119,6,.2);color:#fcd34d}
.btn-duka-mpya{display:flex;align-items:center;gap:6px;padding:7px 10px;color:var(--text3);font-size:11px;cursor:pointer;transition:color .15s;width:100%}
.btn-duka-mpya:hover{color:var(--accent)}

/* User info */
.kando-user{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.08)}
.kando-user-icon{width:36px;height:36px;background:var(--accent);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.kando-user-name{color:#fff;font-weight:700;font-size:12px}
.kando-user-role{font-size:10px;color:var(--text3)}

/* Nav */
.nav-section{padding:12px 0 2px}
.nav-section-title{padding:3px 14px;font-size:9px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:1px}
.nav-item{display:flex;align-items:center;gap:8px;padding:8px 14px;color:#cbd5e1;font-size:12.5px;font-weight:500;cursor:pointer;transition:all .15s;margin:1px 6px;border-radius:7px}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.active{background:rgba(249,115,22,.18);color:#fed7aa}
.nav-icon{font-size:15px;flex-shrink:0;width:18px;text-align:center}
.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}
.kando-bottom{margin-top:auto;padding:12px;border-top:1px solid rgba(255,255,255,.08)}

/* ── TOPBAR ──────────────────────────────────────────────── */
.topbar{background:#fff;border-bottom:1px solid var(--border);padding:0 20px;height:54px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.topbar-left{display:flex;align-items:center;gap:10px}
.topbar-title{font-size:15px;font-weight:800;color:var(--primary)}
.topbar-sub{font-size:11px;color:var(--text2)}
.topbar-right{display:flex;align-items:center;gap:8px}
.btn-menu-toggle{display:none;width:34px;height:34px;align-items:center;justify-content:center;border-radius:7px;background:var(--bg);border:none;cursor:pointer;font-size:18px}
.topbar-duka-badge{display:flex;align-items:center;gap:5px;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:5px 10px;font-size:11px;font-weight:600;color:var(--primary)}

/* ── MAUDHUI ─────────────────────────────────────────────── */
.maudhui{padding:20px;flex:1}

/* ── VIFUNGO ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 15px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .2s;white-space:nowrap;line-height:1}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover:not(:disabled){background:var(--accent2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(249,115,22,.35)}
.btn-secondary{background:var(--primary);color:#fff}
.btn-secondary:hover:not(:disabled){background:var(--primary2)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}
.btn-outline:hover:not(:disabled){background:var(--bg);border-color:var(--text2)}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover:not(:disabled){background:#b91c1c}
.btn-success{background:var(--green);color:#fff}
.btn-success:hover:not(:disabled){background:#15803d}
.btn-warning{background:var(--amber);color:#fff}
.btn-sm{padding:5px 10px;font-size:11.5px}
.btn-lg{padding:12px 24px;font-size:15px}
.btn-block{width:100%}
.btn-round{border-radius:50px}
.btn-icon{width:32px;height:32px;padding:0;border-radius:7px}

/* ── FOMU ────────────────────────────────────────────────── */
.form-group{margin-bottom:15px}
.label{display:block;font-size:11.5px;font-weight:700;color:var(--text2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.4px}
.label.req::after{content:' *';color:var(--red)}
.input{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13.5px;color:var(--text);background:#fff;outline:none;transition:border-color .2s,box-shadow .2s}
.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(249,115,22,.1)}
.input:read-only{background:#f8fafc;color:var(--text2)}
.input.error{border-color:var(--red)}
.input-prefix-wrap{position:relative}
.input-prefix{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:700;color:var(--text2);background:#f1f5f9;padding:2px 6px;border-radius:4px;border:1px solid var(--border)}
.input.has-prefix{padding-left:58px}
select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}
textarea.input{resize:vertical;min-height:80px}
.help-text{font-size:11px;color:var(--text2);margin-top:3px}
.error-text{font-size:11px;color:var(--red);margin-top:3px}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.row-4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px}

/* Radio Card Choices */
.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:8px}
.choice-item{position:relative;cursor:pointer}
.choice-item input{position:absolute;opacity:0;width:0;height:0}
.choice-body{border:2px solid var(--border);border-radius:8px;padding:10px;text-align:center;transition:all .2s;background:#fff}
.choice-item input:checked + .choice-body{border-color:var(--accent);background:#fff7ed}
.choice-icon{font-size:26px;display:block;margin-bottom:3px}
.choice-name{font-size:12.5px;font-weight:700;color:var(--text)}
.choice-desc{font-size:10px;color:var(--text2);margin-top:2px}

/* ── KADI ─────────────────────────────────────────────────── */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border)}
.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.card-title{font-size:14px;font-weight:700;color:var(--text)}
.card-body{padding:18px}
.card-footer{padding:12px 18px;border-top:1px solid var(--border);background:#fafbff;border-radius:0 0 var(--radius) var(--radius)}

/* ── TAKWIMU ──────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:14px;margin-bottom:20px}
.stat-card{background:var(--card);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);border:1px solid var(--border);position:relative;overflow:hidden;transition:transform .2s}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.stat-card::after{content:'';position:absolute;top:-18px;right:-18px;width:70px;height:70px;border-radius:50%;opacity:.08}
.stat-card.orange::after{background:var(--accent)}.stat-card.green::after{background:var(--green)}.stat-card.blue::after{background:var(--blue)}.stat-card.red::after{background:var(--red)}
.stat-icon{width:40px;height:40px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:19px;margin-bottom:12px}
.stat-icon.orange{background:#fff7ed;color:var(--accent)}.stat-icon.green{background:#f0fdf4;color:var(--green)}.stat-icon.blue{background:#eff6ff;color:var(--blue)}.stat-icon.red{background:#fef2f2;color:var(--red)}
.stat-label{font-size:10px;color:var(--text2);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.stat-value{font-size:22px;font-weight:800;color:var(--text);line-height:1}
.stat-value small{font-size:12px;font-weight:500;color:var(--text2)}
.stat-change{font-size:11px;margin-top:5px}
.stat-change.up{color:var(--green)}.stat-change.down{color:var(--red)}

/* ── JEDWALI ──────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;min-width:0}
th{padding:9px 13px;text-align:left;font-size:10.5px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;background:#f8fafc;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:10px 13px;border-bottom:1px solid #f1f5f9;font-size:13px;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:#fafbff}
.table-empty td{text-align:center;padding:48px;color:var(--text2)}

/* ── BEJI ─────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.badge-success{background:#dcfce7;color:#166534}.badge-danger{background:#fee2e2;color:#991b1b}
.badge-warning{background:#fef3c7;color:#92400e}.badge-info{background:#dbeafe;color:#1e40af}
.badge-gray{background:#f1f5f9;color:#475569}.badge-orange{background:#fff7ed;color:#c2410c}
.badge-purple{background:#f5f3ff;color:#6d28d9}

/* ── ARIFA ────────────────────────────────────────────────── */
.alert{padding:11px 15px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:14px;border-left:3px solid}
.alert-success{background:#dcfce7;color:#166534;border-color:var(--green)}.alert-danger{background:#fee2e2;color:#991b1b;border-color:var(--red)}
.alert-warning{background:#fef3c7;color:#92400e;border-color:var(--amber)}.alert-info{background:#dbeafe;color:#1e40af;border-color:var(--blue)}

/* ── MODAL ───────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.48);z-index:400;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadein .2s}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.modal{background:#fff;border-radius:14px;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.25);animation:slidein .22s}
.modal-lg{max-width:740px}.modal-xl{max-width:920px}
@keyframes slidein{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.modal-header{padding:18px 22px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:#fff;z-index:1}
.modal-title{font-size:15px;font-weight:700}
.modal-close{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;background:none;color:var(--text2);font-size:17px;transition:background .15s}
.modal-close:hover{background:#f1f5f9}
.modal-body{padding:20px 22px}
.modal-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:#fff}

/* ── TOAST ────────────────────────────────────────────────── */
#toast-wrap{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:7px}
.toast{background:#1e293b;color:#fff;padding:10px 16px;border-radius:9px;font-size:13px;box-shadow:0 8px 24px rgba(0,0,0,.22);display:flex;align-items:center;gap:8px;min-width:200px;max-width:320px;animation:slidein .3s}
.toast.success{background:#16a34a}.toast.danger{background:#dc2626}.toast.warning{background:#d97706}

/* ── POS ──────────────────────────────────────────────────── */
.pos-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;min-height:calc(100vh - 120px);align-items:start}
.pos-products-col{min-width:0;display:flex;flex-direction:column;overflow:hidden}
.pos-products{overflow-y:auto;max-height:calc(100vh - 140px);padding-right:4px;flex:1;min-height:200px}
.pos-product-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1.5px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;transition:all .15s;margin-bottom:7px}
.pos-product-item:hover{border-color:var(--accent);background:#fffbf5}
.pos-product-item.added{border-color:var(--green);background:#f0fdf4}
.cart-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-bottom:1px solid #f1f5f9;font-size:12.5px}
.qty-controls{display:flex;align-items:center;gap:4px}
.qty-btn{width:22px;height:22px;border-radius:5px;background:#f1f5f9;border:none;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background .15s}
.qty-btn:hover{background:var(--accent);color:#fff}
.cart-panel{background:var(--card);border-radius:var(--radius);border:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:72px;align-self:start;height:auto;max-height:none}
.cart-header{padding:12px 14px;border-bottom:1px solid var(--border);font-weight:700;font-size:13px;display:flex;align-items:center;gap:6px;flex-shrink:0}
.cart-items{flex:0 0 auto;overflow:visible;min-height:60px}
.cart-summary{padding:12px 14px;border-top:1px solid var(--border);background:#fafbff;flex-shrink:0}

/* ── RISITI ───────────────────────────────────────────────── */
.receipt{background:#fff;border:1px solid var(--border);border-radius:var(--radius);max-width:380px;padding:22px;font-size:12.5px;margin:0 auto}
.receipt-header{text-align:center;margin-bottom:14px;padding-bottom:14px;border-bottom:2px dashed var(--border)}
.receipt-shop{font-size:17px;font-weight:800;color:var(--primary);margin-bottom:2px}
.receipt-row{display:flex;justify-content:space-between;padding:3px 0;font-size:12px}
.receipt-total{font-weight:700;font-size:15px;border-top:1px solid var(--border);padding-top:7px;margin-top:5px}
.receipt-footer{text-align:center;margin-top:14px;padding-top:10px;border-top:2px dashed var(--border);font-size:11px;color:var(--text2)}

/* ── STOK BAR ─────────────────────────────────────────────── */
.stok-bar{height:5px;background:#e2e8f0;border-radius:3px;overflow:hidden;width:80px}
.stok-bar-fill{height:100%;border-radius:3px;transition:width .4s}
.stok-bar-fill.good{background:var(--green)}.stok-bar-fill.low{background:var(--amber)}.stok-bar-fill.empty{background:var(--red)}

/* ── VICHUJIO ─────────────────────────────────────────────── */
.filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.search-wrap{position:relative;flex:1;min-width:170px}
.search-wrap input{width:100%;padding:8px 12px 8px 33px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;outline:none;background:#fff;transition:border-color .2s}
.search-wrap input:focus{border-color:var(--accent)}
.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text2);font-size:14px}
.filter-select{padding:8px 28px 8px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:12.5px;background:#fff;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;outline:none;cursor:pointer}
.filter-select:focus{border-color:var(--accent)}

/* ── PAGE HEADER ──────────────────────────────────────────── */
.page-header{margin-bottom:18px;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:10px}
.page-title{font-size:20px;font-weight:800;color:var(--primary)}
.page-desc{font-size:12px;color:var(--text2);margin-top:2px}

/* ── EMPTY STATE ──────────────────────────────────────────── */
.empty-state{text-align:center;padding:56px 20px;color:var(--text2)}
.empty-icon{font-size:50px;margin-bottom:12px;opacity:.3}
.empty-state h3{font-size:15px;font-weight:700;color:var(--text);margin-bottom:5px}
.empty-state p{font-size:12.5px;max-width:250px;margin:0 auto 18px}

/* ── UKURASA WA KUINGIA ───────────────────────────────────── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a2744 0%,#243459 60%,#1a2744 100%);padding:20px}
.login-box{background:#fff;border-radius:18px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.3)}
.login-top{background:var(--primary);padding:28px 28px 22px;text-align:center}
.login-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:5px}
.login-logo-icon{width:44px;height:44px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px}
.login-logo span{font-size:21px;font-weight:800;color:#fff}
.login-desc{color:#94a3b8;font-size:12.5px}
.login-body{padding:26px 28px 28px}

/* ── STEPS (Usajili) ──────────────────────────────────────── */
.steps{display:flex;margin-bottom:24px;counter-reset:step}
.step{flex:1;display:flex;flex-direction:column;align-items:center;font-size:11px;color:var(--text2);position:relative}
.step::before{counter-increment:step;content:counter(step);width:26px;height:26px;border-radius:50%;background:var(--border);color:var(--text2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;margin-bottom:4px;z-index:1}
.step.done::before{background:var(--green);color:#fff}
.step.active::before{background:var(--accent);color:#fff}
.step:not(:last-child)::after{content:'';position:absolute;top:13px;left:54%;width:92%;height:2px;background:var(--border)}
.step.done:not(:last-child)::after{background:var(--green)}

/* ── CHATI ────────────────────────────────────────────────── */
.bar-chart{display:flex;align-items:flex-end;gap:7px;height:140px;padding:8px 0}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.bar-fill{width:100%;background:var(--accent);border-radius:4px 4px 0 0;min-height:4px;opacity:.85;transition:height .5s}
.bar-label{font-size:10px;color:var(--text2)}
.bar-val{font-size:10px;font-weight:600;color:var(--text2)}

/* ── PAGINATION ───────────────────────────────────────────── */
.pagination{display:flex;align-items:center;gap:5px;padding:14px 18px;border-top:1px solid var(--border)}
.page-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:12.5px;font-weight:600;border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:all .15s;text-decoration:none}
.page-btn:hover{background:#f1f5f9}
.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.page-info{margin-left:auto;font-size:11.5px;color:var(--text2)}

/* ── OVERLAY ──────────────────────────────────────────────── */
.backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:199}
.backdrop.show{display:block}

/* ── PRINT ────────────────────────────────────────────────── */
@media print{
  .kando,.topbar,.filter-bar,.page-header .btn,.btn-danger,.modal-footer,#toast-wrap{display:none!important}
  .eneo-kuu{margin-left:0!important}
  .receipt{box-shadow:none;border:none}
}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:1024px){
  .pos-layout{grid-template-columns:1fr}
  .cart-panel{position:relative!important;top:auto!important;max-height:none}
  .pos-products-col{order:2}
  .cart-panel{order:1}
  .row-3{grid-template-columns:1fr 1fr}
}

@media(max-width:900px){
  .row-3{grid-template-columns:1fr 1fr}
}

@media(max-width:768px){
  .kando{transform:translateX(-100%);width:min(280px,88vw)}
  .kando.open{transform:translateX(0)}
  .backdrop.show{display:block}
  .eneo-kuu{margin-left:0;min-width:0}
  .btn-menu-toggle{display:flex!important}
  .topbar{height:auto;min-height:52px;padding:10px 14px;flex-wrap:wrap;gap:8px}
  .topbar-left{flex:1;min-width:0}
  .topbar-right{width:100%;justify-content:flex-start;flex-wrap:wrap;gap:6px}
  .topbar-title{font-size:14px;line-height:1.2}
  .topbar-sub{font-size:10.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .maudhui{padding:12px 14px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat-card{padding:14px}
  .stat-value{font-size:19px}
  .row-2,.row-3,.row-4{grid-template-columns:1fr}
  .card-header{flex-direction:column;align-items:flex-start;gap:8px}
  .card-body,.card-header,.card-footer,.cart-summary{padding-left:14px;padding-right:14px}
  .card-body{padding-top:14px;padding-bottom:14px}
  .modal{max-width:100%;margin:0;border-radius:16px 16px 0 0;max-height:92vh}
  .modal-overlay{align-items:flex-end;padding:0}
  .modal-body{padding:16px}
  .filter-bar{flex-direction:column;align-items:stretch;gap:8px}
  .filter-bar .search-wrap{min-width:0;width:100%}
  .filter-select,.filter-bar input{width:100%}
  .pagination{flex-wrap:wrap;padding:12px 14px}
  .page-info{width:100%;margin-left:0;margin-top:4px}
  .choice-grid{grid-template-columns:1fr}
  .btn{min-height:40px}
  .btn-sm{min-height:36px;padding:7px 11px}
  .qty-btn{width:34px;height:34px;font-size:15px}
  .cart-item{flex-wrap:wrap;gap:10px;padding:10px 12px}
  .cart-item .qty-controls{width:100%;justify-content:flex-end}
  .pos-products{max-height:none;min-height:240px;padding-right:0}
  .pos-product-item{padding:11px 12px;touch-action:manipulation}
  .receipt{max-width:100%;padding:18px}
  .login-page{padding:0;align-items:stretch;min-height:100vh;min-height:100dvh}
  .login-box{max-width:100%;border-radius:0;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}
  .login-body{flex:1}
  .page-header{flex-direction:column;align-items:flex-start}
  .bar-chart{height:120px}
  /* Inline page grids → single column */
  .maudhui > div[style*="grid-template-columns:1fr 1fr"],
  .maudhui > div[style*="grid-template-columns: 1fr 1fr"],
  .maudhui > div[style*="grid-template-columns:1fr 1.1fr"],
  .maudhui > div[style*="grid-template-columns:2fr 1fr"],
  .maudhui > div[style*="grid-template-columns: 2fr 1fr"],
  .maudhui > div[style*="grid-template-columns:repeat(4"],
  .maudhui > div[style*="grid-template-columns: repeat(4"]{
    grid-template-columns:1fr!important;
  }
  .maudhui div[style*="grid-template-columns:1fr 1fr"][style*="margin-bottom"]{
    grid-template-columns:1fr!important;
  }
  .cart-summary div[style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr!important;
  }
  .agizo-row{grid-template-columns:1fr!important;gap:8px!important}
  .agizo-row .btn-icon{align-self:end}
  table{min-width:560px}
  #toast-wrap{left:14px;right:14px;bottom:14px}
  .toast{max-width:none;min-width:0}
}

@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .stat-value{font-size:18px}
  .topbar-sub{display:none}
  .btn-lg{padding:13px 18px;font-size:14px}
  th,td{padding:8px 10px;font-size:12px}
  .badge{font-size:10px;padding:2px 7px}
  .empty-state{padding:36px 16px}
  .duka-sasa-card{padding:10px}
}

@media(hover:none) and (pointer:coarse){
  .nav-item,.btn,.pos-product-item,.nav-link{min-height:44px}
  .filter-select,.input,select.input{min-height:44px;font-size:16px}
  input[type="number"],input[type="tel"],input[type="date"]{font-size:16px}
}
