/* ============================================================
   FabricPOS - Main Stylesheet
   ============================================================ */
:root {
  --pr:#E85D26; --prl:#FF7A45; --prs:#FFF0EB;
  --bg:#F5F0EB; --sf:#FFFFFF; --sf2:#F7F3EF; --bd:#EAE2D8;
  --tx:#1A1208; --tx2:#6B5E52; --tx3:#B0A090;
  --su:#2D6A4F; --sus:#ECFDF5;
  --wa:#E9A835; --was:#FFFBEB;
  --da:#D93025; --das:#FFF1F0;
  --in:#1976D2; --ins:#EFF6FF;
  --r:16px; --nh:68px; --hh:58px; --sw:260px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--tx);-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{font-family:'Syne',sans-serif;}
a{text-decoration:none;color:inherit;}

/* ── LAYOUT ── */
.app-wrap{display:flex;height:100vh;overflow:hidden;}

/* SIDEBAR */
.sidebar{width:var(--sw);background:white;border-right:1px solid var(--bd);display:flex;flex-direction:column;flex-shrink:0;height:100vh;overflow:hidden;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:200;}
.sidebar-hdr{background:linear-gradient(135deg,var(--pr),var(--prl));padding:22px 20px 18px;flex-shrink:0;}
.sid-av{width:48px;height:48px;border-radius:16px;background:rgba(255,255,255,.25);border:2px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;color:white;font-family:'Syne',sans-serif;font-size:20px;font-weight:700;margin-bottom:10px;}
.sid-name{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;color:white;}
.sid-shop{font-size:11px;color:rgba(255,255,255,.75);margin-top:3px;display:flex;align-items:center;gap:5px;}
.sid-shop span{width:6px;height:6px;border-radius:50%;background:#8AFF8A;display:inline-block;}
.sidebar-body{flex:1;overflow-y:auto;padding:8px;scrollbar-width:none;}
.sidebar-body::-webkit-scrollbar{display:none;}
.sid-slbl{font-size:10px;font-weight:700;color:var(--tx3);letter-spacing:1.2px;text-transform:uppercase;padding:10px 10px 4px;}
.sid-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;cursor:pointer;font-size:13px;font-weight:500;color:var(--tx2);margin-bottom:1px;text-decoration:none;}
.sid-item:hover{background:var(--sf2);}
.sid-item.active{background:var(--prs);color:var(--pr);font-weight:600;}
.sid-ic{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;background:var(--sf2);color:var(--tx3);flex-shrink:0;}
.sid-item.active .sid-ic{background:var(--prs);color:var(--pr);}
.sid-badge{margin-left:auto;background:var(--pr);color:white;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;}
.sidebar-foot{padding:10px 8px 16px;border-top:1px solid var(--bd);}
.sid-logout{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:12px;cursor:pointer;font-size:13px;font-weight:600;color:var(--da);background:rgba(217,48,37,.06);text-decoration:none;}
.sid-logout:hover{background:rgba(217,48,37,.12);}

/* MAIN AREA */
.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;}

/* TOP HEADER */
.top-hdr{height:var(--hh);background:white;border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0;box-shadow:0 1px 8px rgba(0,0,0,.05);z-index:100;}
.hdr-toggle{width:36px;height:36px;border-radius:11px;background:var(--sf2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--tx2);font-size:15px;display:none;}
.hdr-brand{display:flex;align-items:center;gap:8px;flex:1;min-width:0;}
.hdr-bic{width:30px;height:30px;border-radius:9px;background:var(--pr);display:flex;align-items:center;justify-content:center;color:white;font-size:13px;flex-shrink:0;}
.hdr-title{font-family:'Syne',sans-serif;font-size:16px;font-weight:700;color:var(--tx);}
.hdr-right{display:flex;gap:8px;align-items:center;}
.hdr-btn{width:36px;height:36px;border-radius:11px;background:var(--sf2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--tx2);font-size:14px;position:relative;text-decoration:none;}
.hdr-btn:hover{background:var(--bd);}
.hdr-dot{width:8px;height:8px;border-radius:50%;background:var(--pr);border:2px solid white;position:absolute;top:5px;right:5px;}
.hdr-shop-name{font-size:12px;font-weight:600;color:var(--tx3);display:none;}

/* PAGE CONTENT */
.page-content{flex:1;overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch;}
.page-content::-webkit-scrollbar{width:4px;}
.page-content::-webkit-scrollbar-thumb{background:var(--bd);border-radius:4px;}

/* ── COMPONENTS ── */
/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:12px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;border:none;text-decoration:none;transition:.15s;}
.btn:active{transform:scale(.97);}
.btn-p{background:linear-gradient(135deg,var(--pr),var(--prl));color:white;box-shadow:0 4px 14px rgba(232,93,38,.3);}
.btn-o{background:white;color:var(--tx2);border:1.5px solid var(--bd);}
.btn-d{background:rgba(217,48,37,.1);color:var(--da);border:1.5px solid rgba(217,48,37,.2);}
.btn-sm{padding:7px 12px;font-size:12px;border-radius:9px;}
.btn-xs{padding:5px 9px;font-size:11px;border-radius:8px;}

/* Pills */
.pill{display:inline-flex;align-items:center;gap:3px;padding:4px 9px;border-radius:20px;font-size:11px;font-weight:700;}
.pg{background:var(--sus);color:var(--su);}
.po{background:var(--was);color:var(--wa);}
.pr-pill{background:var(--das);color:var(--da);}
.pb{background:var(--ins);color:var(--in);}

/* Cards */
.card{background:white;border-radius:var(--r);border:1px solid var(--bd);overflow:hidden;margin-bottom:16px;}
.card-hdr{padding:14px 18px 12px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;}
.card-t{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;}
.card-body{padding:16px 18px;}

/* Page header */
.pg-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap;}
.pg-title{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;}
.pg-sub{font-size:13px;color:var(--tx3);margin-top:3px;}

/* Stat Grid */
.sgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;}
.sc{background:white;border-radius:var(--r);padding:16px;border:1px solid var(--bd);}
.sic{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:12px;}
.sv{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;line-height:1.1;}
.sl{font-size:12px;color:var(--tx3);margin-top:4px;}
.sch{font-size:11px;margin-top:6px;font-weight:600;display:flex;align-items:center;gap:3px;}
.cu{color:var(--su);}.cd{color:var(--da);}

/* Chips */
.crow{display:flex;gap:8px;overflow-x:auto;margin-bottom:14px;padding-bottom:4px;scrollbar-width:none;flex-wrap:wrap;}
.crow::-webkit-scrollbar{display:none;}
.chip{padding:7px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;border:1.5px solid var(--bd);background:white;color:var(--tx2);transition:.15s;}
.chip:hover,.chip.on{background:var(--pr);color:white;border-color:var(--pr);}

/* Table */
.tbl-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:13px;}
thead th{background:var(--sf2);padding:10px 14px;text-align:left;font-weight:700;font-size:11px;color:var(--tx3);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;}
tbody tr{border-bottom:1px solid var(--bd);}
tbody tr:hover{background:var(--sf2);}
tbody td{padding:12px 14px;vertical-align:middle;}

/* Form */
.ff{margin-bottom:14px;}
.ff label{font-size:11px;font-weight:700;color:var(--tx2);display:block;margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px;}
.ff input,.ff select,.ff textarea{width:100%;padding:11px 13px;border:1.5px solid var(--bd);border-radius:11px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--tx);background:var(--sf2);outline:none;transition:.2s;}
.ff input:focus,.ff select:focus,.ff textarea:focus{border-color:var(--pr);background:white;}
.ff textarea{resize:vertical;height:80px;}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* Alert */
.alert{padding:12px 16px;border-radius:12px;font-size:13px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.alert-err{background:var(--das);color:var(--da);border:1.5px solid rgba(217,48,37,.2);}
.alert-ok{background:var(--sus);color:var(--su);border:1.5px solid rgba(45,106,79,.2);}

/* Toggle */
.trow{display:flex;align-items:center;justify-content:space-between;padding:13px;background:var(--bg);border-radius:11px;margin-bottom:8px;}
.tog{position:relative;width:44px;height:24px;cursor:pointer;flex-shrink:0;}
.tog input{opacity:0;width:0;height:0;}
.togtr{position:absolute;inset:0;border-radius:24px;}
.togtr::after{content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:white;transition:transform .2s;box-shadow:0 1px 4px rgba(0,0,0,.2);}
.tog input:checked+.togtr{background:var(--pr);}
.tog input:checked+.togtr::after{transform:translateX(20px);}
.tog input:not(:checked)+.togtr{background:var(--bd);}

/* Search box */
.srchbox{display:flex;align-items:center;gap:8px;background:white;border:1.5px solid var(--bd);border-radius:12px;padding:10px 14px;margin-bottom:12px;}
.srchbox i{color:var(--tx3);font-size:13px;}
.srchbox input{border:none;background:transparent;font-family:'DM Sans',sans-serif;font-size:14px;outline:none;width:100%;}

/* ── MOBILE RESPONSIVE ── */
@media (max-width: 768px) {
  :root{--hh:56px;--nh:64px;}
  .sidebar{position:fixed;top:0;left:0;height:100%;transform:translateX(-100%);z-index:300;}
  .sidebar.open{transform:translateX(0);box-shadow:4px 0 24px rgba(0,0,0,.15);}
  .sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:299;display:none;backdrop-filter:blur(3px);}
  .sidebar-overlay.show{display:block;}
  .hdr-toggle{display:flex;}
  .main-area{width:100%;}
  .sgrid{grid-template-columns:1fr 1fr;}
  .fr{grid-template-columns:1fr;}
  .page-content{padding:14px;}
  .top-hdr{padding:0 14px;gap:8px;}
  /* Bottom nav on mobile */
  .bot-nav{display:flex;}
  .page-content{padding-bottom:80px;}
}
@media (min-width: 769px) {
  .bot-nav{display:none;}
}

/* BOTTOM NAV - mobile only */
.bot-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nh);background:white;border-top:1px solid var(--bd);align-items:center;padding:0 4px;z-index:100;box-shadow:0 -2px 16px rgba(0,0,0,.06);}
.bni{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;padding:6px 2px;border-radius:10px;text-decoration:none;}
.bnic{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:17px;color:var(--tx3);}
.bni.active .bnic{background:var(--prs);color:var(--pr);}
.bnlbl{font-size:10px;font-weight:600;color:var(--tx3);}
.bni.active .bnlbl{color:var(--pr);}

/* Bar chart */
.bchart{display:flex;align-items:flex-end;gap:8px;height:120px;padding:0 4px;}
.bw{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;}
.bar{width:100%;border-radius:6px 6px 0 0;min-height:8px;}
.blbl{font-size:10px;color:var(--tx3);font-weight:500;}

/* Report bar */
.rbar-item{margin-bottom:12px;}
.rbar-label{display:flex;justify-content:space-between;font-size:12px;margin-bottom:5px;}
.rbar-track{height:8px;background:var(--bd);border-radius:4px;overflow:hidden;}
.rbar-fill{height:100%;border-radius:4px;}

/* Inv card */
.invcard{background:white;border-radius:var(--r);border:1.5px solid var(--bd);padding:14px;margin-bottom:10px;display:flex;align-items:center;gap:14px;}
.invcard:hover{border-color:var(--pr);}
.invem{font-size:28px;flex-shrink:0;}
.invi{flex:1;min-width:0;}
.invn{font-size:14px;font-weight:600;}
.invsku{font-size:11px;color:var(--tx3);font-family:monospace;margin-top:2px;}
.invprices{display:flex;gap:16px;margin-top:8px;}
.invprice{text-align:center;}
.invplbl{font-size:10px;color:var(--tx3);display:block;}
.invpv{font-size:13px;font-weight:700;}
.invstv{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;}

/* Customer card */
.cust-card{background:white;border-radius:var(--r);border:1px solid var(--bd);padding:14px;display:flex;align-items:center;gap:12px;margin-bottom:10px;cursor:pointer;text-decoration:none;color:inherit;}
.cust-card:hover{border-color:var(--pr);}
.cust-av{width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,var(--pr),var(--prl));display:flex;align-items:center;justify-content:center;color:white;font-family:'Syne',sans-serif;font-weight:700;font-size:18px;flex-shrink:0;}

/* Udhar card */
.ucard{background:white;border-radius:var(--r);border:1.5px solid var(--bd);padding:16px;margin-bottom:10px;}
.uamt{font-family:'Syne',sans-serif;font-size:20px;font-weight:800;color:var(--da);}

/* Plan cards */
.planc{background:white;border-radius:18px;border:2px solid var(--bd);padding:20px;margin-bottom:14px;position:relative;}
.planc.pop{border-color:var(--pr);}
.planc.pop::before{content:'POPULAR';position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--pr);color:white;padding:3px 12px;border-radius:20px;font-size:9px;font-weight:800;letter-spacing:1px;}
.plann{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;margin-bottom:6px;}
.planp{font-family:'Syne',sans-serif;font-size:30px;font-weight:800;color:var(--pr);}
.planp span{font-size:14px;color:var(--tx3);font-family:'DM Sans',sans-serif;font-weight:400;}
.planf{margin:12px 0;list-style:none;}
.planf li{font-size:13px;color:var(--tx2);padding:4px 0;display:flex;align-items:center;gap:7px;}
.planf li::before{content:'✓';color:var(--su);font-weight:700;}

/* Toast */
.toast-wrap{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;}
.toast{background:#1A1208;color:white;padding:12px 18px;border-radius:12px;font-size:13px;font-weight:600;animation:tin .3s ease;box-shadow:0 8px 24px rgba(0,0,0,.2);min-width:200px;}
@keyframes tin{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
@media(max-width:768px){.toast-wrap{left:12px;right:12px;bottom:80px;}.toast{min-width:0;}}

/* ── PRINT STYLES ── */
@media print {
  .sidebar, .top-hdr, .bot-nav, .sidebar-overlay,
  .btn, button, .crow, nav, .hdr-toggle, .hdr-right,
  .toast-wrap, #modalOv { display: none !important; }
  .main-area { width: 100% !important; }
  .page-content { padding: 0 !important; overflow: visible !important; }
  body { background: white !important; }
  .card { border: 1px solid #ddd !important; box-shadow: none !important; page-break-inside: avoid; }
  table { font-size: 12px; }
  .app-wrap { display: block !important; }
}
