:root {
  --ink:    #1a2340;
  --ink2:   #2a3560;
  --navy:   #1e2d5a;
  --rose:   #7b9e6b;
  --rose-d: #5a7a4e;
  --rose-l: #f0f5ee;
  --rose-m: #c8dcc2;
  --gold:   #8faacc;
  --gold-l: #eef3f9;
  --sage:   #5a7a9e;
  --sage-l: #eaf0f6;
  --cream:  #f8faf5;
  --border: #dde8d8;
  --muted:  #7a8a9a;
  --label:  #1e2d5a;
  --white:  #ffffff;
  --shadow: 0 2px 16px rgba(26,35,64,.08);
  --shadow-lg: 0 8px 40px rgba(26,35,64,.14);
  --blue:   #4a6e9e;
  --blue-l: #eef3f9;
  --grad-start: #b8cfa8;
  --grad-end:   #b0b8d8;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Jost',sans-serif;background:var(--cream);color:var(--ink);min-height:100vh;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;z-index:-1;
  background:linear-gradient(160deg,rgba(184,207,168,.12) 0%,rgba(248,250,245,0) 40%,rgba(176,184,216,.08) 100%);
  pointer-events:none;}

/* ── LOGIN ────────────────────────────────────────────────────────── */
#login-screen {
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#c8d8b8 0%,#d0d8e8 50%,#b8c0d8 100%);
  position:relative;overflow:hidden;
}
#login-screen::before {
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 60% at 20% 30%,rgba(255,255,255,.4) 0%,transparent 60%),
             radial-gradient(ellipse 50% 50% at 80% 70%,rgba(180,200,220,.3) 0%,transparent 60%);
}
.login-box {
  position:relative;z-index:1;width:400px;
  background:rgba(255,255,255,.75);border:1px solid rgba(255,255,255,.9);
  border-radius:24px;padding:44px 40px;backdrop-filter:blur(24px);
  box-shadow:0 24px 80px rgba(26,35,64,.2);
}
.login-brand{text-align:center;margin-bottom:36px;}
.login-shared-logo{
  width:64px;height:64px;border-radius:50%;object-fit:cover;display:block;
  margin:0 auto 10px;border:2px solid rgba(30,45,90,.16);box-shadow:0 6px 20px rgba(26,35,64,.12);
}
.login-brand .icon{width:52px;height:52px;background:linear-gradient(135deg,var(--rose),#8a2f3f);
  border-radius:14px;display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:14px;box-shadow:0 4px 16px rgba(181,72,90,.4);}
.login-brand h1{color:var(--navy);font-family:'Cormorant Garamond',serif;font-size:1.8rem;letter-spacing:.5px;}
.login-brand p{color:var(--muted);font-size:.82rem;margin-top:4px;letter-spacing:.8px;text-transform:uppercase;}
.lf{margin-bottom:18px;}
.lf label{display:block;font-size:.75rem;font-weight:600;color:var(--label);
  text-transform:uppercase;letter-spacing:.6px;margin-bottom:7px;}
.lf input{width:100%;padding:12px 16px;background:rgba(255,255,255,.8);
  border:1.5px solid var(--border);border-radius:10px;color:var(--ink);
  font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s;}
.lf input:focus{border-color:var(--sage);background:#fff;}
.lf input::placeholder{color:#aab;}
.btn-login{width:100%;padding:13px;margin-top:6px;
  background:linear-gradient(135deg,var(--navy) 0%,var(--ink2) 100%);
  color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:600;
  font-family:inherit;cursor:pointer;transition:opacity .2s,transform .1s;letter-spacing:.3px;}
.btn-login:hover{opacity:.9;transform:translateY(-1px);}
.login-err{color:#c0392b;font-size:.82rem;text-align:center;margin-top:10px;min-height:20px;}
.login-wordmark{display:flex;flex-direction:column;align-items:center;line-height:1.1;margin-bottom:6px;}
.login-wm-graze{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:700;color:var(--navy);letter-spacing:.04em;}
.login-wm-boutique{font-family:'Jost',sans-serif;font-size:.72rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);}

/* ── TOUCH: ensure interactive elements are easy to tap ─────────── */
button,select,input{-webkit-tap-highlight-color:transparent;}
.nav-tab{min-height:36px;display:flex;align-items:center;}

/* ── APP SHELL ────────────────────────────────────────────────────── */
#app{display:none;flex-direction:column;min-height:100vh;overflow-x:hidden;}
header{background:linear-gradient(135deg,var(--navy) 0%,var(--ink2) 100%);color:#fff;
  display:flex;align-items:center;padding:0 24px;gap:16px;
  box-shadow:0 2px 16px rgba(26,35,64,.25);
  position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(255,255,255,.08);
  height:62px;flex-wrap:nowrap;}
.h-brand{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.h-brand-dot{display:none;}
.h-brand span{font-family:'Cormorant Garamond',serif;font-size:1.1rem;}
.nav-tabs{display:flex;gap:2px;flex:1;justify-content:center;}
.nav-tab{padding:6px 16px;font-size:.78rem;font-weight:500;cursor:pointer;
  color:rgba(255,255,255,.5);border-radius:7px;transition:all .2s;
  text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;}
.nav-tab:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.06);}
.nav-tab.active{color:#fff;background:rgba(255,255,255,.12);}
.nav-tab.hidden{display:none;}
/* ── NAV GROUPS ──────────────────────────────────────────────────── */
.nav-group{position:relative;display:flex;align-items:center;}
.nav-group.hidden{display:none;}
.nav-group-btn{
  display:flex;align-items:center;gap:4px;
  padding:6px 14px;font-size:.78rem;font-weight:500;
  cursor:pointer;color:rgba(255,255,255,.5);border-radius:7px;
  transition:all .2s;text-transform:uppercase;letter-spacing:.5px;
  white-space:nowrap;background:none;border:none;font-family:inherit;min-height:36px;
}
.nav-group-btn:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.06);}
.nav-group-btn.active{color:#fff;background:rgba(255,255,255,.12);}
.nav-group-arrow{font-size:.65rem;opacity:.6;transition:transform .2s;display:inline-block;}
.nav-group.open .nav-group-arrow{transform:rotate(180deg);}
.nav-group-dropdown{
  display:none;position:absolute;top:calc(100% + 4px);left:0;
  background:linear-gradient(135deg,var(--navy) 0%,var(--ink2) 100%);
  border:1px solid rgba(255,255,255,.12);border-radius:10px;
  padding:6px;z-index:200;min-width:155px;
  box-shadow:0 8px 24px rgba(26,35,64,.35);flex-direction:column;gap:2px;
}
.nav-group:last-child .nav-group-dropdown{right:0;left:auto;}
.nav-group.open .nav-group-dropdown{display:flex;}
.nav-group-dropdown .nav-tab{padding:8px 14px;border-radius:7px;width:100%;justify-content:flex-start;}
.nav-group-dropdown .nav-tab.hidden{display:none;}
.h-right{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-shrink:0;margin-left:auto;}
#mobile-footer-logo{display:none;}
.mobile-footer-tab{display:none;}
.role-badge{padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;}
/* ── USER MENU DROPDOWN ─────────────────────────────────────────── */
.user-menu{position:relative;display:flex;align-items:center;}
.user-menu-btn{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:4px;padding:4px 6px;border-radius:7px;transition:background .15s;}
.user-menu-btn:hover{background:rgba(255,255,255,.08);}
.user-menu-dropdown{display:none;position:absolute;right:0;top:calc(100% + 8px);
  background:#fff;border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.18);
  min-width:180px;flex-direction:column;overflow:hidden;z-index:500;
  border:1px solid var(--border);}
.user-menu.open .user-menu-dropdown{display:flex;}
.user-menu-item{background:none;border:none;padding:11px 16px;text-align:left;
  font-size:.85rem;font-family:inherit;cursor:pointer;color:var(--navy);
  transition:background .15s;width:100%;}
.user-menu-item:hover{background:var(--cream);}
.user-menu-signout{color:#dc2626;border-top:1px solid var(--border);}
.role-admin{background:rgba(143,170,204,.25);color:#c8daea;}
.role-sales{background:rgba(181,72,90,.2);color:#e8a0a8;}
.btn-logout{background:none;border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.6);
  padding:5px 12px;border-radius:7px;cursor:pointer;font-size:.78rem;font-family:inherit;transition:all .2s;}
.btn-logout:hover{border-color:var(--rose);color:#fff;}

/* ── MOBILE NAV ───────────────────────────────────────────────────── */
@media (max-width:700px){
  header{
    height:auto;
    padding:10px 14px 0;
    flex-wrap:wrap;
    gap:0;
  }
  .h-brand{flex:1;padding-bottom:8px;}
  .h-right{padding-bottom:8px;margin-left:auto;}
  .nav-tabs{
    order:3;width:100%;
    overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    gap:2px;
    padding:4px 0 8px;
    border-top:1px solid rgba(255,255,255,.08);
    justify-content:flex-start;
  }
  .nav-tabs::-webkit-scrollbar{display:none;}
  .nav-tab{
    display:flex;flex-direction:column;align-items:center;
    gap:2px;padding:5px 12px 4px;
    font-size:0;/* hide full text */
    letter-spacing:0;
  }
  .nav-tab::before{content:attr(data-icon);font-size:1.15rem;line-height:1;}
  .nav-tab::after{content:attr(data-short);font-size:.6rem;font-weight:600;
    text-transform:uppercase;letter-spacing:.4px;opacity:.75;line-height:1;}
  .nav-tab.active::after{opacity:1;}
  .page{padding:14px 12px;}
}

/* ── PAGES ────────────────────────────────────────────────────────── */
.page{display:none;padding:24px;max-width:1300px;margin:0 auto;width:100%;}
.page.active{display:block;}

/* ── PANEL ────────────────────────────────────────────────────────── */
.panel{background:var(--white);border-radius:16px;border:1px solid var(--border);
  box-shadow:var(--shadow);overflow:hidden;}
.panel.panel-search{overflow:visible;}
.panel.panel-search .panel-head{overflow:visible;}
.panel.panel-search .panel-body{overflow:visible;}
.panel-head{padding:14px 20px;border-bottom:1px solid var(--border);
  background:linear-gradient(135deg,rgba(184,207,168,.15) 0%,rgba(176,184,216,.1) 100%);
  display:flex;align-items:center;justify-content:space-between;}
.panel-head h2{font-size:.75rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.6px;color:var(--label);display:flex;align-items:center;gap:7px;}
.panel-body{padding:20px;}

.mobile-record-list{
  display:none;
  padding:12px;
  background:#fbfcfa;
  border-top:1px solid var(--border);
}
.mobile-record-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:0 2px 14px rgba(26,35,64,.06);
  padding:12px;
}
.mobile-record-card + .mobile-record-card{
  margin-top:10px;
}
.mobile-record-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  margin-bottom:8px;
}
.mobile-record-title{
  font-size:.92rem;
  font-weight:700;
  color:var(--navy);
}
.mobile-record-subtitle{
  margin-top:2px;
  font-size:.76rem;
  color:var(--muted);
}
.mobile-record-amount{
  font-size:.95rem;
  font-weight:700;
  color:var(--navy);
  white-space:nowrap;
}
.mobile-record-amount.expense{
  color:#e53935;
}
.mobile-record-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px 12px;
}
.mobile-record-field{
  min-width:0;
}
.mobile-record-label{
  font-size:.66rem;
  font-weight:700;
  color:var(--muted);
  text-transform:uppercase;
  letter-spacing:.05em;
}
.mobile-record-value{
  margin-top:2px;
  font-size:.82rem;
  color:var(--ink);
  word-break:break-word;
}
.mobile-record-actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
  margin-top:10px;
}

/* ── SALES PAGE LAYOUT ────────────────────────────────────────────── */
#page-sales .sales-grid{
  display:grid;
  grid-template-columns:400px 1fr;
  grid-template-rows:auto 1fr;
  gap:20px;
}

/* ── CUSTOMER BAR ─────────────────────────────────────────────────── */
.customer-bar{
  grid-column:1/-1;
  background:var(--white);border-radius:12px;border:1px solid var(--border);
  padding:14px 20px;display:flex;align-items:center;gap:16px;
  box-shadow:var(--shadow);
}
.sale-mode-tabs{
  display:flex;
  gap:0;
  align-items:center;
  padding:3px;
  min-height:48px;
  background:linear-gradient(180deg,#eef3f0 0%,#e6ece8 100%);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.sale-actions-row{
  display:flex;
  align-items:center;
  gap:12px;
}
.sale-mode-tabs button{
  min-height:40px;
  border:none;
  background:transparent;
  color:var(--muted);
  border-radius:11px;
  padding:8px 14px;
  font-size:.78rem;
  font-weight:700;
  cursor:pointer;
  font-family:inherit;
  transition:background .18s,border-color .18s,color .18s,box-shadow .18s,transform .12s;
  position:relative;
  line-height:1;
  white-space:nowrap;
  text-transform:uppercase;
}
.sale-mode-tabs button:hover{color:var(--navy);}
.sale-mode-tabs button.active{
  background:linear-gradient(135deg,var(--navy),var(--ink2));
  color:#fff;
  box-shadow:0 4px 14px rgba(26,35,64,.22), inset 0 0 0 1px rgba(255,255,255,.12);
}
.customer-bar input{
  flex:1;
  min-height:48px;
  padding:11px 14px;
  border:1.5px solid var(--border);
  border-radius:12px;
  font-size:.95rem;
  font-family:inherit;
  outline:none;
  background:linear-gradient(180deg,#ffffff 0%,#f7fbf4 100%);
  transition:border-color .2s,box-shadow .2s,background .2s;
  box-shadow:0 4px 12px rgba(90,122,78,.08);
}
.customer-bar input:focus{
  border-color:var(--rose);
  background:#fff;
  box-shadow:0 0 0 3px rgba(90,122,78,.12), 0 6px 16px rgba(90,122,78,.12);
}
.btn-open-orders{
  border:1px solid var(--border);
  background:#fff;
  color:var(--navy);
  border-radius:8px;
  padding:8px 11px;
  font-size:.78rem;
  font-weight:600;
  cursor:pointer;
  font-family:inherit;
  white-space:nowrap;
}
.btn-open-orders:hover{border-color:var(--navy);}
.btn-customer-action{
  border:1px solid var(--border);
  background:#fff;
  color:var(--navy);
  border-radius:8px;
  padding:8px 12px;
  font-size:.78rem;
  font-weight:600;
  cursor:pointer;
  font-family:inherit;
  transition:all .15s;
}
.btn-customer-action:hover{
  border-color:var(--navy);
  background:var(--gold-l);
}
.sale-pay-method{
  display:flex;
  align-items:center;
  gap:0;
  min-height:48px;
  border:1px solid var(--border);
  background:linear-gradient(180deg,#eef3f0 0%,#e6ece8 100%);
  border-radius:14px;
  padding:3px;
  white-space:nowrap;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
}
.pay-method-btn{
  min-height:40px;
  border:none;
  background:transparent;
  color:var(--muted);
  border-radius:11px;
  padding:8px 14px;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.2px;
  cursor:pointer;
  transition:all .15s;
  font-family:inherit;
  line-height:1;
  text-transform:uppercase;
}
.pay-method-btn:hover{color:var(--navy);}
.pay-method-btn.active{
  background:linear-gradient(135deg,var(--navy),var(--ink2));
  color:#fff;
  box-shadow:0 4px 14px rgba(26,35,64,.22), inset 0 0 0 1px rgba(255,255,255,.12);
}
.session-info{display:flex;align-items:center;gap:20px;margin-left:auto;white-space:nowrap;}
.session-stat .sv{font-size:1.1rem;font-weight:700;color:var(--navy);
  font-family:'Cormorant Garamond',serif;}
.session-stat .sl{font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;}
.btn-complete{
  min-height:48px;
  padding:10px 18px;
  background:linear-gradient(135deg,var(--rose-d) 0%,#3a5a38 100%);
  color:#fff;border:none;border-radius:14px;font-size:.82rem;font-weight:700;
  font-family:inherit;cursor:pointer;white-space:nowrap;
  transition:opacity .2s,transform .1s;display:flex;align-items:center;gap:7px;
  line-height:1;
  box-shadow:0 6px 16px rgba(58,90,56,.16);
}
.btn-complete:hover{opacity:.9;transform:translateY(-1px);}
.btn-complete:disabled{opacity:.4;cursor:not-allowed;transform:none;}

/* ── SEARCH / ITEM ────────────────────────────────────────────────── */
.search-wrap{position:relative;margin-bottom:16px;}
.search-wrap input{width:100%;min-height:48px;padding:11px 40px 11px 14px;
  border:2px solid var(--border);border-radius:10px;font-size:.95rem;
  font-family:inherit;outline:none;background:var(--cream);transition:border-color .2s;
  box-sizing:border-box;}
.search-wrap input:focus{border-color:var(--rose);background:#fff;}
.search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--muted);cursor:pointer;font-size:1rem;}
.search-clear:hover{color:var(--rose);}
.ac-list{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:200;
  background:#fff;border:1.5px solid var(--rose-m);border-radius:10px;
  box-shadow:var(--shadow-lg);max-height:240px;overflow-y:auto;display:none;}
.ac-row{padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;transition:background .15s;}
.ac-row:last-child{border-bottom:none;}
.ac-row:hover{background:var(--rose-l);}
.ar-id{font-size:.75rem;font-weight:700;color:var(--rose);font-family:monospace;}
.ar-price{font-size:.8rem;font-weight:600;color:var(--sage);}

/* Returns/Edit Item autocomplete dropdown */
.ac-dropdown{
  position:absolute;
  top:calc(100% + 4px);
  left:0;
  right:0;
  z-index:220;
  background:#fff;
  border:1.5px solid var(--rose-m);
  border-radius:10px;
  box-shadow:var(--shadow-lg);
  max-height:240px;
  overflow-y:auto;
  display:none;
}
.ac-item{
  display:grid;
  grid-template-columns:120px 1fr auto;
  gap:10px;
  align-items:center;
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background .15s;
}
.ac-item:last-child{border-bottom:none;}
.ac-item:hover{background:var(--rose-l);}
.ac-code{
  font-family:monospace;
  font-size:.76rem;
  font-weight:700;
  color:var(--navy);
}
.ac-desc{
  font-size:.84rem;
  color:var(--ink);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.ac-price{
  font-size:.82rem;
  font-weight:600;
  color:var(--sage);
  white-space:nowrap;
}

.notes-field{width:100%;padding:9px 12px;margin-bottom:12px;border:1.5px solid var(--border);
  border-radius:8px;font-size:.87rem;font-family:inherit;resize:none;outline:none;}
.notes-field:focus{border-color:var(--rose-m);}
.btn-scan{
  min-height:48px;
  padding:10px 14px;
  background:linear-gradient(135deg,var(--navy),var(--ink2));
  color:#fff;border:none;border-radius:10px;
  font-size:.82rem;font-weight:600;font-family:inherit;
  cursor:pointer;white-space:nowrap;flex-shrink:0;
  display:flex;align-items:center;gap:6px;
  justify-content:center;
  transition:opacity .2s;border:1px solid rgba(255,255,255,.1);
  box-sizing:border-box;
}
.btn-scan:hover{opacity:.85;}
@keyframes scanline{0%{top:0%}100%{top:100%}}
/* ── SESSION BASKET ───────────────────────────────────────────────── */
.basket-empty{text-align:center;padding:40px 20px;color:var(--muted);font-size:.88rem;}
.basket-empty svg{color:var(--border);margin-bottom:10px;}
.basket-table{width:100%;border-collapse:collapse;font-size:.84rem;}
.basket-table thead th{background:var(--navy);color:#fff;padding:9px 14px;
  text-align:left;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;}
.basket-table tbody tr{border-bottom:1px solid var(--border);transition:background .15s;}
.basket-table tbody tr:hover{background:var(--rose-l);}
.basket-table td{padding:9px 14px;vertical-align:middle;}
.tag-id{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.7rem;
  font-weight:700;background:var(--gold-l);color:var(--navy);}
.price-gbp{font-weight:700;color:var(--navy);}
.btn-remove,.btn-edit{background:none;border:none;cursor:pointer;
  padding:4px 6px;border-radius:6px;transition:all .15s;display:inline-flex;align-items:center;}
.btn-remove{color:#c8c8d4;}
.btn-remove:hover{color:#c0392b;background:rgba(192,57,43,.08);}
.btn-edit{color:#8faacc;}
.btn-edit:hover{color:var(--navy);background:rgba(26,35,64,.08);}
.action-btns{display:flex;gap:2px;justify-content:flex-end;}

/* Inline edit row */
.edit-row td{background:linear-gradient(135deg,rgba(184,207,168,.12),rgba(176,184,216,.1));
  padding:10px 14px;}
.edit-row input[type=number]{width:100px;padding:6px 10px;border:1.5px solid var(--border);
  border-radius:7px;font-size:.9rem;font-family:inherit;outline:none;text-align:center;}
.edit-row input[type=number]:focus{border-color:var(--sage);}
.edit-row textarea{width:100%;padding:6px 10px;border:1.5px solid var(--border);
  border-radius:7px;font-size:.82rem;font-family:inherit;outline:none;resize:none;margin-top:6px;}
.edit-row textarea:focus{border-color:var(--sage);}
.btn-save-edit{padding:6px 14px;background:linear-gradient(135deg,var(--navy),var(--ink2));
  color:#fff;border:none;border-radius:7px;font-size:.8rem;font-weight:600;
  font-family:inherit;cursor:pointer;margin-top:6px;}
.btn-cancel-edit{padding:6px 12px;background:none;border:1px solid var(--border);
  color:var(--muted);border-radius:7px;font-size:.8rem;font-family:inherit;cursor:pointer;margin-top:6px;margin-left:4px;}
.basket-footer{padding:14px 20px;border-top:2px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  background:var(--cream);}
.basket-total{font-size:1.1rem;font-weight:700;}
.basket-total span{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--navy);}

/* ── ADMIN PAGES ──────────────────────────────────────────────────── */
.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
.stat-card{background:var(--white);border-radius:12px;border:1px solid var(--border);
  padding:20px 24px;box-shadow:var(--shadow);}
.stat-card .sc-val{font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:700;color:var(--navy);}
.stat-card .sc-lbl{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-top:2px;}
.log-table{width:100%;border-collapse:collapse;font-size:.92rem;font-family:'Jost',sans-serif;letter-spacing:.01em;}
.log-table thead th{background:var(--navy);color:#fff;padding:10px 14px;text-align:left;
  font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;}
.log-table tbody tr{border-bottom:1px solid var(--border);}
.log-table tbody tr:hover{background:var(--rose-l);}
.log-table td{padding:9px 14px;}
.log-empty{text-align:center;padding:40px;color:var(--muted);font-size:.88rem;}

/* ── USERS PAGE ───────────────────────────────────────────────────── */
.users-layout{display:grid;grid-template-columns:320px 1fr;gap:20px;}
.uf{margin-bottom:13px;}
.uf label{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;
  letter-spacing:.5px;color:var(--label);margin-bottom:5px;}
.uf input,.uf select{width:100%;padding:10px 13px;border:1.5px solid var(--border);
  border-radius:8px;font-size:.9rem;font-family:inherit;outline:none;background:var(--cream);}
.uf input:focus,.uf select:focus{border-color:var(--rose);background:#fff;}
.btn-create{width:100%;padding:11px;background:linear-gradient(135deg,var(--rose),var(--rose-d));
  color:#fff;border:none;border-radius:8px;font-size:.88rem;font-weight:600;
  font-family:inherit;cursor:pointer;transition:opacity .2s;}
.btn-create:hover{opacity:.88;}
.btn-primary{padding:8px 20px;background:linear-gradient(135deg,var(--rose),var(--rose-d));
  color:#fff;border:none;border-radius:8px;font-size:.88rem;font-weight:600;
  font-family:inherit;cursor:pointer;transition:opacity .2s;white-space:nowrap;}
.btn-primary:hover{opacity:.88;}
.btn-sm{padding:5px 13px;background:linear-gradient(135deg,var(--rose),var(--rose-d));
  color:#fff;border:none;border-radius:7px;font-size:.8rem;font-weight:600;
  font-family:inherit;cursor:pointer;transition:opacity .2s;white-space:nowrap;}
.btn-sm:hover{opacity:.88;}
.btn-secondary{padding:5px 13px;background:var(--cream);color:var(--ink);
  border:1.5px solid var(--border);border-radius:7px;font-size:.8rem;font-weight:600;
  font-family:inherit;cursor:pointer;transition:opacity .2s;white-space:nowrap;}
.btn-secondary:hover{background:var(--border);}
.users-table{width:100%;border-collapse:collapse;font-size:.84rem;}
.users-table thead th{background:var(--navy);color:#fff;padding:10px 14px;text-align:left;
  font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;}
.users-table tbody tr{border-bottom:1px solid var(--border);}
.users-table tbody tr:hover{background:var(--cream);}
.users-table td{padding:10px 14px;}
.role-pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;}
.rp-admin{background:var(--gold-l);color:var(--gold);}
.rp-sales{background:var(--rose-l);color:var(--rose);}
.rp-demo{background:#e0f2fe;color:#0369a1;}
.role-demo{background:rgba(3,105,161,.25);color:#93c5fd;}
.btn-del{background:none;border:1px solid #ddd;color:var(--muted);
  padding:4px 10px;border-radius:6px;cursor:pointer;font-size:.75rem;transition:all .2s;}
.btn-del:hover{border-color:var(--rose);color:var(--rose);}
.form-err{font-size:.78rem;color:var(--rose);margin-top:6px;min-height:18px;}
.rpt-filter-btn{padding:6px 14px;background:none;border:1.5px solid var(--border);
  color:var(--muted);border-radius:20px;font-size:.78rem;font-family:inherit;cursor:pointer;transition:all .2s;}
.rpt-filter-btn:hover{border-color:var(--navy);color:var(--navy);}
.rpt-filter-btn.active{background:var(--navy);border-color:var(--navy);color:#fff;}
.sold-row{background:rgba(90,122,158,.04);}
.remaining-row{background:rgba(184,207,168,.06);}
.profit-pos{color:#2e7d52;font-weight:700;}
.profit-neg{color:#c0392b;font-weight:700;}
.rpt-actions{display:flex;gap:8px;align-items:stretch;margin-bottom:13px;}

/* Report table in monochrome for cleaner, low-ink printing */
#rpt-table thead th{
  background:#fff;
  color:var(--ink);
  border-bottom:1px solid #bbb;
}
#rpt-table tbody tr:hover{background:transparent;}

/* ── IMPORT ───────────────────────────────────────────────────────── */
.drop-zone{border:2px dashed var(--border);border-radius:14px;padding:52px 28px;
  text-align:center;cursor:pointer;transition:all .2s;background:var(--cream);}
.drop-zone:hover,.drop-zone.drag{border-color:var(--rose);background:var(--rose-l);}
.drop-zone svg{color:var(--rose);margin-bottom:12px;}
.import-res{margin:16px auto 0;padding:14px 18px;border-radius:10px;font-size:.88rem;
  font-weight:500;display:none;}
.import-res.ok{background:var(--sage-l);color:var(--sage);display:block;}
.import-res.err{background:#fdeaea;color:#c94040;display:block;}

/* ── TOAST ────────────────────────────────────────────────────────── */
#toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:10px;
  font-size:.88rem;font-weight:600;color:#fff;box-shadow:0 4px 20px rgba(0,0,0,.2);
  transform:translateY(60px);opacity:0;transition:all .3s;z-index:9999;min-width:220px;}
#toast.show{transform:translateY(0);opacity:1;}
#toast.ok{background:var(--sage);}
#toast.err{background:var(--rose);}

/* ── RESPONSIVE: TABLET + DESKTOP (≤900px) ───────────────────────── */
@media(max-width:900px){
  #page-sales .sales-grid{grid-template-columns:1fr;}
  .admin-grid{grid-template-columns:1fr;}
  .users-layout{grid-template-columns:1fr;}
  .session-info{display:none;}
  /* Customers page: single column */
  #page-customers > div[style*="340px"]{grid-template-columns:1fr!important;}

  /* Nav: allow horizontal scroll instead of wrapping/overflow */
  .nav-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-shrink:1;min-width:0;justify-content:flex-start;}
  .nav-tabs::-webkit-scrollbar{display:none;}

  /* Header: tighten spacing */
  header{padding:0 14px;gap:10px;}
  .h-brand span{font-size:.95rem;}

  /* Pages */
  .page{padding:16px;}

  /* Customer bar: allow items to wrap */
  .customer-bar{flex-wrap:wrap;gap:10px;}
  .sale-mode-tabs,.sale-pay-method,.btn-complete,.customer-bar input{min-height:44px;}
  .sale-mode-tabs button,.pay-method-btn{min-height:36px;}
  .customer-bar input{flex:1 1 140px;min-width:0;}
  #customer-phone{flex:1 1 120px;}
  .sale-actions-row{width:100%;justify-content:flex-end;}
}

/* ── CUSTOMER DATASHEET: mobile layout ───────────────────────────── */
/* cust-item cards */
.cust-item{background:var(--white);border:1px solid var(--border);border-radius:10px;
  padding:10px 14px;cursor:pointer;transition:background .15s;}
.cust-item:hover{background:var(--bg);}
.ci-name{font-weight:600;font-size:.88rem;color:var(--navy);}
.ci-phone{font-size:.78rem;color:var(--muted);margin-top:2px;}
.cust-summary-grid .stat-card,
.cust-detail-summary-grid .stat-card{
  min-width:0;
}

/* ── RESPONSIVE: TABLET (≤768px) ─────────────────────────────────── */
@media(max-width:768px){
  /* Header: hide username text on tablet */
  #h-name{display:none;}
  .role-badge{font-size:.65rem;padding:2px 8px;}
  header,.page,.panel,.panel-body,.customer-bar{min-width:0;max-width:100%;}
  input,select,textarea,button{max-width:100%;}

  /* Panels */
  .panel-body{padding:14px;}
  .panel-head{padding:10px 14px;}

  /* Datasheet: single-column layout, hide list when form is shown */
  #ds-layout{grid-template-columns:1fr!important;}
  #page-datasheet.ds-selected #ds-left{display:none;}
  #page-suppliers > div[style*="340px"]{grid-template-columns:1fr!important;}
  #page-suppliers.sup-selected > div[style*="340px"] > div:first-child{display:none;}

  /* Report filter grid: 2 cols instead of auto-fill */
  #page-reports .panel-body > div[style*="grid"]{grid-template-columns:1fr 1fr!important;}

  /* Basket table: horizontal scroll */
  #basket-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .basket-table{min-width:520px;}

  /* Log / admin tables: horizontal scroll wrapper (applied via JS polyfill below) */
  .table-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .log-table,.users-table{min-width:560px;}

  /* Customer sessions table */
  #cust-sessions table{font-size:.75rem;}
  #cust-sessions th,#cust-sessions td{padding:6px 8px;}
  .cust-summary-grid{
    display:none !important;
  }
  .cust-detail-summary-grid{display:none !important;}

  /* Stat cards: 2-column on tablet */
  .admin-grid{grid-template-columns:1fr 1fr;}

  /* QR modal full-width */
  #qr-modal > div{width:calc(100vw - 40px)!important;max-width:360px;}
}

/* ── RESPONSIVE: PHONE (≤480px) ──────────────────────────────────── */
@media(max-width:480px){
  /* Login box: edge-to-edge with breathing room */
  .login-box{width:calc(100vw - 32px);padding:32px 22px;border-radius:18px;}
  .login-brand h1{font-size:1.5rem;}

  /* Header: tighter, single row */
  header{height:54px;padding:0 12px;gap:8px;}
  .h-brand span{display:none;}   /* hide wordmark, keep dot/icon */
  .h-brand-dot{display:inline-block;width:28px;height:28px;
    background:linear-gradient(135deg,var(--rose),var(--rose-d));
    border-radius:8px;flex-shrink:0;}
  .nav-tab{padding:5px 11px;font-size:0;line-height:1;}
  #h-name{display:none;}

  /* Pages: minimal padding on phone */
  .page{padding:10px;}

  /* Customer bar: stack vertically */
  .customer-bar{flex-direction:column;align-items:stretch;gap:8px;padding:12px;}
  .customer-bar input{flex:none;width:100%;}
  #customer-phone{flex:none;min-width:0;}
  .sale-actions-row{width:100%;justify-content:stretch;}
  .btn-complete{margin-top:0;}
  #page-returns .customer-bar label{
    width:100%;
    margin:0;
  }
  #page-returns .customer-bar .search-wrap{
    flex:1 1 auto;
    min-width:0;
  }
  #ret-scan-btn{
    flex:0 0 auto;
    min-height:32px;
    min-width:44px;
    padding:6px 10px;
  }
  #page-suppliers.sup-selected > div[style*="340px"] > div:first-child{display:none;}
  #page-suppliers #sup-detail-wrap .panel-head,
  #page-suppliers #sup-form-wrap .panel-head{
    flex-direction:column;
    align-items:flex-start !important;
    gap:10px !important;
  }
  #page-suppliers #sup-detail-wrap .panel-head > div:last-child{
    display:flex;
    flex-direction:column;
    width:100%;
    gap:8px !important;
    align-items:stretch !important;
  }
  #page-suppliers #sup-detail-wrap .panel-head > div:last-child button{
    width:100%;
  }
  .cust-summary-grid{display:none !important;}
  .cust-detail-summary-grid{display:none !important;}
  /* Stat cards: single column */
  .admin-grid{grid-template-columns:1fr;}
  .stat-card .sc-val{font-size:1.5rem;}

  /* Report filter: single column */
  #page-reports .panel-body > div[style*="grid"]{grid-template-columns:1fr!important;}

  /* Datasheet: single-column form fields */
  .ds-fields-grid{grid-template-columns:1fr!important;}

  /* Basket table: hide size & description cols */
  .basket-table th:nth-child(3),
  .basket-table td:nth-child(3),
  .basket-table th:nth-child(4),
  .basket-table td:nth-child(4){display:none;}
  .basket-table{min-width:0;}
  #basket-wrap{overflow-x:unset;}

  /* Basket footer: stack */
  .basket-footer{flex-direction:column;gap:6px;align-items:flex-start;}

  /* Panels */
  .panel-body{padding:12px;}
  .panel-head{padding:9px 12px;}
  .panel-head h2{font-size:.7rem;}

  /* Users layout already 1-col, shrink form fields */
  .uf input,.uf select{font-size:.88rem;}

  /* Toast: full width bottom bar */
  #toast{left:12px;right:12px;bottom:14px;min-width:0;text-align:center;}

  /* QR modal: full screen */
  #qr-modal > div{width:calc(100vw - 24px)!important;padding:18px!important;}

  /* Import drop zone */
  .drop-zone{padding:32px 16px;}

  /* Customer sessions table: scroll */
  #cust-sessions{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  #cust-sessions table{min-width:420px;font-size:.73rem;}

  .ac-item{grid-template-columns:92px 1fr auto;gap:8px;padding:9px 10px;}
  .ac-code{font-size:.72rem;}
  .ac-desc{font-size:.8rem;}
  .ac-price{font-size:.78rem;}

  #page-history .panel,
  #page-offerings .panel,
  #page-expenses .panel{
    border-radius:14px;
  }
  #page-history .admin-grid{
    grid-template-columns:repeat(4, minmax(0, 1fr));
    gap:8px;
  }
  #page-history .stat-card{
    min-width:0;
    padding:10px 8px;
  }
  #page-history .stat-card .sc-val{
    font-size:1rem;
  }
  #page-history .stat-card .sc-lbl{
    font-size:.58rem;
    line-height:1.2;
  }
  .mobile-form-row,
  .mobile-filter-bar,
  .mobile-toolbar{
    flex-direction:column;
    align-items:stretch !important;
  }
  .mobile-form-row > .uf,
  .mobile-form-row > button,
  .mobile-filter-bar > div,
  .mobile-filter-bar > button,
  .mobile-toolbar > button,
  .mobile-toolbar > select,
  .mobile-toolbar > span{
    width:100%;
  }
  .mobile-form-row > .uf{
    flex:none !important;
    min-width:0 !important;
  }
  .mobile-form-row > button{
    flex:none !important;
    align-self:stretch;
  }
  .mobile-filter-bar > div[style*="display:flex"],
  .mobile-toolbar{
    gap:8px !important;
  }
  .mobile-summary-grid{
    display:grid !important;
    grid-template-columns:1fr 1fr;
    gap:10px !important;
  }
  .mobile-summary-grid > div{
    min-width:0 !important;
    padding:10px;
    border:1px solid var(--border);
    border-radius:12px;
    background:#fff;
  }
  .mobile-table-wrap,
  .mobile-data-table{
    display:none !important;
  }
  .mobile-record-list{
    display:block;
  }
  .mobile-record-grid{
    grid-template-columns:1fr;
    gap:8px;
  }
  .mobile-record-actions{
    justify-content:stretch;
  }
  .mobile-record-actions button{
    width:100%;
  }
  #page-history .panel-head,
  #page-offerings .panel-head,
  #page-expenses .panel-head{
    align-items:flex-start;
    gap:10px;
  }
  #page-history .panel-head h2,
  #page-offerings .panel-head h2,
  #page-expenses .panel-head h2{
    font-size:.74rem;
  }
  #page-history .history-toolbar{
    flex-direction:row;
    align-items:center !important;
    justify-content:space-between;
    flex-wrap:nowrap !important;
    gap:6px !important;
    width:100%;
  }
  #page-history .history-toolbar label,
  #page-history .history-toolbar select,
  #page-history .history-toolbar button,
  #page-history .history-toolbar span{
    width:auto;
  }
  #page-history .history-toolbar label{
    font-size:.66rem !important;
  }
  #page-history .history-toolbar select,
  #page-history .history-toolbar button{
    min-width:0;
    padding:5px 8px !important;
    font-size:.72rem !important;
  }
  #page-history .history-toolbar span{
    min-width:auto !important;
    font-size:.72rem !important;
    white-space:nowrap;
  }
  #page-history .history-filter-bar{
    display:grid !important;
    grid-template-columns:1fr 1fr;
    gap:10px 8px !important;
    align-items:end !important;
  }
  #page-history .history-filter-duration,
  #page-history .history-filter-desc,
  #page-history .history-filter-from,
  #page-history .history-filter-to,
  #page-history .history-filter-apply,
  #page-history .history-filter-clear{
    width:100% !important;
    min-width:0 !important;
  }
  #page-history .history-filter-duration{
    grid-column:1;
  }
  #page-history .history-filter-desc{
    grid-column:2;
  }
  #page-history .history-filter-from{
    grid-column:1;
  }
  #page-history .history-filter-to{
    grid-column:2;
  }
  #page-history .history-filter-apply{
    grid-column:1;
  }
  #page-history .history-filter-clear{
    grid-column:2;
  }
  #page-history .history-filter-bar > div[style*="display:flex"]{
    gap:inherit !important;
  }
  #page-history .history-filter-bar input,
  #page-history .history-filter-bar select{
    width:100%;
  }
  #page-expenses #exp-custom-dates{
    width:100%;
    flex-direction:column;
    align-items:stretch !important;
  }
  #page-expenses #exp-custom-dates > div,
  #page-expenses #exp-custom-dates > button{
    width:100%;
  }
}

/* ── RESPONSIVE: MOBILE FOOTER ACCOUNT BAR (≤700px) ─────────────── */
@media(max-width:700px){
  #app{padding-bottom:60px;}
  .page{padding-bottom:72px;}
  .sale-mode-tabs{
    width:100%;
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:0;
    padding:2px;
    background:linear-gradient(180deg,#eef3f0 0%,#e6ece8 100%);
    border:1px solid var(--border);
    border-radius:12px;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
  }
  .sale-mode-tabs button{
    width:100%;
    min-height:28px;
    font-size:.68rem;
    font-weight:700;
    border:none;
    border-radius:9px;
    background:transparent;
    color:#607083;
    letter-spacing:.02em;
    text-transform:uppercase;
    box-shadow:none;
    padding:4px 2px;
    line-height:1;
  }
  .sale-mode-tabs button.active{
    background:linear-gradient(135deg,var(--navy),var(--ink2));
    color:#fff;
    border:none;
    box-shadow:0 4px 14px rgba(26,35,64,.22), inset 0 0 0 1px rgba(255,255,255,.12);
    transform:translateY(-1px);
  }
  .sale-mode-tabs button[aria-selected="false"]{
    opacity:.92;
  }
  .sale-actions-row{
    width:100%;
    display:grid;
    grid-template-columns:minmax(0, 2fr) minmax(0, 1fr);
    align-items:stretch;
    gap:5px;
  }
  .sale-pay-method{
    width:100%;
    justify-content:space-between;
    min-width:0;
    gap:0;
    padding:2px;
    background:linear-gradient(180deg,#eef3f0 0%,#e6ece8 100%);
    border:1px solid var(--border);
    border-radius:12px;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
  }
  .pay-method-btn{
    flex:1;
    min-height:28px;
    font-size:.7rem;
    padding:4px 6px;
    line-height:1;
    border:none;
    border-radius:9px;
    background:transparent;
    color:#607083;
    font-weight:700;
    letter-spacing:.02em;
    text-transform:uppercase;
    box-shadow:none;
  }
  .pay-method-btn.active{
    background:linear-gradient(135deg,var(--navy),var(--ink2));
    color:#fff;
    border:none;
    box-shadow:0 4px 14px rgba(26,35,64,.22), inset 0 0 0 1px rgba(255,255,255,.12);
  }
  .pay-method-btn:not(.active){
    opacity:.92;
  }
  .btn-complete{
    width:100%;
    min-height:28px;
    justify-content:center;
    padding:6px 8px;
    font-size:.72rem;
    gap:4px;
  }
  #panel-find-item{
    background:transparent;
    border:none;
    box-shadow:none;
    border-radius:0;
    overflow:visible;
  }
  #panel-find-item .panel-head{
    display:none;
  }
  #panel-find-item .panel-body{
    padding:0;
    background:transparent;
  }
  #panel-find-item .panel-body > div:first-child{
    margin-bottom:0 !important;
    align-items:stretch !important;
  }
  #panel-find-item .search-wrap input{
    min-height:28px;
    padding:7px 32px 7px 10px;
    font-size:.78rem;
    border:2px solid rgba(90,122,78,.42);
    border-radius:12px;
    background:linear-gradient(180deg,#ffffff 0%,#f7fbf4 100%);
    box-shadow:0 6px 18px rgba(90,122,78,.14);
  }
  #panel-find-item .search-wrap::before{
    content:"";
    position:absolute;
    inset:-3px;
    border-radius:14px;
    background:linear-gradient(135deg,rgba(184,207,168,.32),rgba(143,170,204,.18));
    z-index:-1;
  }
  #panel-find-item .search-wrap input::placeholder{
    color:#53667b;
    font-weight:600;
    letter-spacing:.01em;
  }
  #panel-find-item .search-wrap input:focus{
    border-color:var(--rose-d);
    background:#fff;
    box-shadow:0 0 0 3px rgba(90,122,78,.16), 0 8px 20px rgba(90,122,78,.16);
  }
  #panel-find-item .search-clear{
    right:10px;
    font-size:.85rem;
  }
  #panel-find-item .btn-scan{
    min-height:28px;
    padding:6px 10px;
    border-radius:10px;
    font-size:.72rem;
    gap:4px;
  }
  #panel-find-item .btn-scan svg{
    width:15px;
    height:15px;
  }
  header{
    padding:6px 10px;
    height:auto;
    min-height:0;
    gap:0;
  }
  .h-brand{display:none;}
  .nav-tabs{
    order:1;
    width:100%;
    padding:2px 0 4px;
    border-top:none;
    justify-content:flex-start;
  }
  .nav-group,.nav-group.hidden{display:contents;}
  .nav-group-btn{display:none;}
  .nav-group-dropdown{display:contents !important;position:static;background:none;border:none;padding:0;border-radius:0;box-shadow:none;min-width:0;}
  #tab-import,#tab-users{display:none !important;}
  /* Mobile nav order: Sales, Reports, Invoices, Returns, Customers, ... */
  #tab-reports{order:1;}
  #tab-invoices{order:2;}
  #tab-returns{order:3;}
  #tab-customers{order:4;}
  /* Remaining in natural order: */
  #tab-datasheet{order:5;}
  #tab-suppliers{order:6;}
  #tab-expenses{order:7;}
  #tab-charts{order:8;}
  #tab-history{order:9;}
  #tab-offerings{order:10;}
  #tab-balance-sheet{order:11;}
  #tab-edititem{order:12;}
  #tab-combos{order:13;}
  .h-right{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    height:56px;
    padding:0 12px calc(env(safe-area-inset-bottom,0px));
    margin-left:0;
    background:linear-gradient(135deg,var(--navy) 0%,var(--ink2) 100%);
    border-top:1px solid rgba(255,255,255,.12);
    box-shadow:0 -4px 16px rgba(26,35,64,.25);
    z-index:150;
    justify-content:space-between;
    align-items:center;
    gap:8px;
  }
  #mobile-footer-logo{
    display:block;
    width:30px;
    height:30px;
    border-radius:50%;
    object-fit:cover;
    border:1.5px solid rgba(255,255,255,.35);
    flex-shrink:0;
  }
  .mobile-footer-tab{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border:1px solid rgba(255,255,255,.2);
    background:rgba(255,255,255,.08);
    color:rgba(255,255,255,.9);
    border-radius:999px;
    padding:5px 10px;
    font-size:.7rem;
    font-weight:600;
    letter-spacing:.35px;
    text-transform:uppercase;
    cursor:pointer;
  }
  .mobile-footer-tab.active{
    background:rgba(255,255,255,.2);
    border-color:rgba(255,255,255,.35);
  }
  .mobile-footer-tab.hidden{display:none;}
  #h-name{
    display:block !important;
    max-width:38vw;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:.8rem !important;
    color:rgba(255,255,255,.82) !important;
  }
  .btn-logout{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    padding:5px 10px;
    font-size:.74rem;
  }
}

@keyframes spin{to{transform:rotate(360deg)}}
.cust-item {
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:8px;
  background:#fff;
  cursor:pointer;
  transition:all .15s;
}
.cust-item:hover {
  border-color:var(--rose);
  background:var(--rose-l);
}
.ci-name {
  font-weight:600;
  color:var(--navy);
  font-size:.85rem;
}
.ci-phone {
  font-size:.75rem;
  color:var(--muted);
  margin-top:2px;
}
/* ── EXPENSES + BALANCE SHEET ───────────────────────────────────── */
.exp-range-btn,.bs-range-btn{
  padding:5px 14px;border:1.5px solid var(--border);background:#fff;
  border-radius:20px;font-size:.78rem;font-weight:600;cursor:pointer;
  font-family:inherit;color:var(--muted);transition:all .15s;
}
.exp-range-btn:hover,.bs-range-btn:hover{border-color:var(--rose);color:var(--navy);}
.exp-range-btn.active,.bs-range-btn.active{border-color:var(--navy);background:var(--navy);color:#fff;}
.exp-row{border-bottom:1px solid var(--border);transition:background .12s;}
.exp-row:hover{background:#fff8f0;}
.exp-row td{padding:10px 12px;vertical-align:middle;}
.exp-del-btn{padding:4px 10px;border-radius:6px;border:1.5px solid var(--border);background:#fff;
  color:#e53935;font-size:.75rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .15s;}
.exp-del-btn:hover{background:#fee2e2;border-color:#e53935;}

/* ── INVOICES PAGE ─────────────────────────────────────────────── */
.inv-range-btn{
  padding:5px 14px;border:1.5px solid var(--border);background:#fff;
  border-radius:20px;font-size:.78rem;font-weight:600;cursor:pointer;
  font-family:inherit;color:var(--muted);transition:all .15s;
}
.inv-range-btn:hover{border-color:var(--rose);color:var(--navy);}
.inv-range-btn.active{border-color:var(--navy);background:var(--navy);color:#fff;}
.inv-row{border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s;}
.inv-row:hover{background:#f9fbf7;}
.inv-row td{padding:11px 8px;vertical-align:middle;}
.inv-expand-btn{
  width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border);
  background:#fff;cursor:pointer;font-size:.75rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;color:var(--navy);flex-shrink:0;
}
.inv-expand-btn.open{background:var(--navy);border-color:var(--navy);color:#fff;transform:rotate(45deg);}
.inv-detail-row td{padding:0;}
.inv-detail-inner{
  padding:10px 16px 14px 36px;background:#f5f8f2;
  border-bottom:1px solid var(--border);
}
.inv-detail-table{width:100%;border-collapse:collapse;font-size:.8rem;}
.inv-detail-table th{padding:5px 8px;text-align:left;color:var(--muted);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;}
.inv-detail-table td{padding:6px 8px;border-top:1px solid var(--border);color:var(--navy);}
.inv-action-btn{
  padding:5px 12px;border-radius:7px;border:1.5px solid var(--border);
  background:#fff;cursor:pointer;font-size:.78rem;font-weight:600;
  font-family:inherit;color:var(--navy);transition:all .15s;white-space:nowrap;
}
.inv-action-btn:hover{border-color:var(--navy);background:var(--navy);color:#fff;}
.inv-action-btn.wa{border-color:#25D366;color:#25D366;}
.inv-action-btn.wa:hover{background:#25D366;color:#fff;}

/* ── STITCHING PAGE ────────────────────────────────────────────── */
.stitch-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto 1fr;
  gap:16px;
  max-width:900px;
  margin:0 auto;
}
.stitch-grid .customer-bar{
  grid-column:1/-1;
}
@media(max-width:700px){
  .stitch-grid{grid-template-columns:1fr;}
}
