/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{height:100%;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{font-family:-apple-system,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;height:100%;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .3s,color .3s}
button{font-family:inherit;cursor:pointer;border:none;background:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
input,textarea,select{font-family:inherit;font-size:16px} /* 16px prevents iOS zoom */
textarea{font-size:15px}
.hidden{display:none!important}

/* ── LIGHT THEME ── */
:root,[data-theme="light"]{
  --bg:#f0f2f5;--surface:#fff;--surface2:#f7f8fa;--surface3:#eef0f3;
  --border:#e2e5ea;--text:#1a1a2e;--text2:#5c6374;--text3:#9ca3af;
  --blue:#0d47a1;--blue-mid:#1565c0;--blue-lt:#e8f0fe;--blue-txt:#0d47a1;
  --green:#059669;--green-lt:#d1fae5;--amber:#d97706;--amber-lt:#fef3c7;
  --red:#dc2626;--red-lt:#fee2e2;
  --header-bg:#0d47a1;--header-txt:#fff;--drawer-bg:#fff;
  --shadow:0 1px 4px rgba(0,0,0,.08);--shadow-md:0 2px 10px rgba(0,0,0,.1);
}
/* ── DARK THEME ── */
[data-theme="dark"]{
  --bg:#0f1117;--surface:#1c1f2e;--surface2:#252838;--surface3:#2e3244;
  --border:#363a52;--text:#e8eaf6;--text2:#9ba3c9;--text3:#636b8a;
  --blue:#5c8fff;--blue-mid:#4a7cf7;--blue-lt:#1a2340;--blue-txt:#7aaeff;
  --green:#34d399;--green-lt:#064e3b;--amber:#fbbf24;--amber-lt:#451a03;
  --red:#f87171;--red-lt:#450a0a;
  --header-bg:#141728;--header-txt:#e8eaf6;--drawer-bg:#1c1f2e;
  --shadow:0 1px 6px rgba(0,0,0,.35);--shadow-md:0 2px 14px rgba(0,0,0,.4);
}
body{background:var(--bg);color:var(--text)}

/* ── SPLASH ── */
.splash{position:fixed;inset:0;background:#0d47a1;display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .4s}
.splash.fade-out{opacity:0;pointer-events:none}
.splash-inner{text-align:center;padding:20px}
.splash-logo-wrap{margin-bottom:20px;animation:pop .5s ease}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.splash-name{font-size:32px;font-weight:800;color:#fff;letter-spacing:.5px;margin-bottom:6px}
.splash-tag{font-size:14px;color:rgba(255,255,255,.65);margin-bottom:32px}
.splash-bar{width:130px;height:3px;background:rgba(255,255,255,.2);border-radius:2px;overflow:hidden;margin:0 auto 16px}
.splash-fill{height:100%;background:#69f0ae;border-radius:2px;animation:fillBar 1.4s ease forwards}
@keyframes fillBar{from{width:0}to{width:100%}}
.splash-credit{font-size:12px;color:rgba(255,255,255,.4)}

/* ── WIZARD ── */
.wizard-overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:flex-start;justify-content:center;z-index:900;padding:0;overflow-y:auto;-webkit-overflow-scrolling:touch}
.wizard-scroll{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px 16px;width:100%}
.wizard-box{background:var(--surface);border-radius:20px;padding:28px 22px;width:100%;max-width:400px;box-shadow:var(--shadow-md)}
.wizard-logo{text-align:center;margin-bottom:16px}
.wizard-title{font-size:22px;font-weight:800;color:var(--text);text-align:center;margin-bottom:6px}
.wizard-sub{font-size:14px;color:var(--text2);text-align:center;margin-bottom:22px;line-height:1.5}
.wiz-info-box{background:var(--blue-lt);border-radius:12px;padding:13px 14px;font-size:13px;color:var(--blue-txt);margin-bottom:22px;line-height:1.6;display:flex;gap:10px;align-items:flex-start}
.btn-wizard{width:100%;padding:15px;background:var(--blue-mid);color:#fff;border-radius:14px;font-size:16px;font-weight:700;transition:background .15s;margin-top:4px}
.btn-wizard:active{background:var(--blue)}

/* ── APP ── */
.app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}

/* ── HEADER ── */
.header{background:var(--header-bg);color:var(--header-txt);padding:0 14px;height:58px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;z-index:100;position:relative}
.header{padding-top:env(safe-area-inset-top,0)}
.header-left{display:flex;align-items:center;gap:8px;min-width:0;flex:1}
.icon-btn{color:rgba(255,255,255,.9);padding:9px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.icon-btn:active{background:rgba(255,255,255,.15)}
.header-title-block{min-width:0;flex:1}
.header-title{font-size:16px;font-weight:700;color:var(--header-txt);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.header-sub{font-size:11px;color:rgba(255,255,255,.55);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.header-right{display:flex;align-items:center;gap:7px;flex-shrink:0}
.sync-pill{display:flex;align-items:center;gap:4px;background:rgba(255,255,255,.12);border-radius:20px;padding:4px 9px;font-size:11px;color:rgba(255,255,255,.85)}
.sync-dot{width:6px;height:6px;border-radius:50%;background:#69f0ae;flex-shrink:0}
.sync-dot.syncing{animation:pulse 1s infinite;background:#fbbf24}
.sync-dot.error{background:#f87171}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
.theme-btn{color:rgba(255,255,255,.85);padding:9px;border-radius:10px;display:flex;align-items:center}
.theme-btn:active{background:rgba(255,255,255,.15)}
[data-theme="light"] .icon-moon{display:none}
[data-theme="dark"] .icon-sun{display:none}
.avatar-btn{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.2);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.3);transition:transform .15s,background .15s;flex-shrink:0}
.avatar-btn:active{transform:scale(.9);background:rgba(255,255,255,.35)}

/* ── DRAWER ── */
.drawer-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200}
.drawer-overlay.open{display:block}
.drawer{position:fixed;top:0;left:-295px;width:295px;height:100%;background:var(--drawer-bg);z-index:201;display:flex;flex-direction:column;transition:left .28s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 24px rgba(0,0,0,.2)}
.drawer.open{left:0}
.drawer-head{background:var(--blue-mid);padding:20px 16px 16px}
.drawer-head{padding-top:calc(20px + env(safe-area-inset-top,0))}
.drawer-logo-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.d-appname{color:#fff;font-size:18px;font-weight:800}
.d-sitename{color:rgba(255,255,255,.6);font-size:12px;margin-top:2px}
.d-userrow{display:flex;align-items:center;gap:10px}
.d-avatar{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.2);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.3);flex-shrink:0}
.d-username{color:#fff;font-size:14px;font-weight:600}
.d-code{color:rgba(255,255,255,.55);font-size:11px;margin-top:1px}
.drawer-nav{flex:1;padding:10px 0;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:14px;width:100%;padding:14px 20px;font-size:14px;color:var(--text2);text-align:left;border-left:3px solid transparent;transition:background .15s,color .15s}
.nav-item svg{flex-shrink:0;opacity:.7}
.nav-item:active{background:var(--blue-lt);color:var(--blue-txt)}
.nav-item.active{background:var(--blue-lt);color:var(--blue-txt);border-left-color:var(--blue-mid);font-weight:700}
.nav-item.active svg{opacity:1}
.nav-divider{height:1px;background:var(--border);margin:8px 0}
.drawer-foot{padding:14px 18px 24px;border-top:1px solid var(--border)}
.d-credit{font-size:11px;color:var(--text3)}
.d-ver{font-size:11px;color:var(--text3);margin-top:2px}

/* ── MAIN ── */
.main-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.page{display:none;padding:14px 14px 110px;animation:fadeIn .2s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ── WEEK HERO ── */
.week-hero{background:linear-gradient(135deg,var(--blue-mid),var(--blue));border-radius:16px;padding:16px 18px;color:#fff;display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:16px}
.wh-lbl{font-size:10px;opacity:.7;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.wh-dates{font-size:16px;font-weight:700}
.wh-today{font-size:14px;font-weight:600}

/* ── METRICS ── */
.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:18px}
.metric-card{background:var(--surface);border-radius:14px;padding:15px;box-shadow:var(--shadow)}
.metric-val{font-size:30px;font-weight:800;color:var(--text);line-height:1;margin-bottom:5px}
.metric-lbl{font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}
.metric-card.warn .metric-val{color:var(--amber)}
.metric-card.danger .metric-val{color:var(--red)}
.metric-card.good .metric-val{color:var(--green)}

/* ── SECTION HEADERS ── */
.sec-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.sec-title{font-size:12px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.8px}
.text-btn{font-size:13px;color:var(--blue-txt);font-weight:600;padding:5px 10px;border-radius:8px;background:var(--blue-lt)}
.text-btn:active{opacity:.7}

/* ── STOCK ITEM CARDS (dashboard) ── */
.stock-item-card{background:var(--surface);border-radius:14px;padding:14px;display:flex;align-items:center;gap:12px;margin-bottom:8px;box-shadow:var(--shadow)}
.sic-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0;background:var(--blue-lt);color:var(--blue-txt)}
.sic-icon.level-low{background:var(--amber-lt);color:var(--amber)}
.sic-icon.level-critical{background:var(--red-lt);color:var(--red)}
.sic-info{flex:1;min-width:0}
.sic-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:3px}
.sic-detail{font-size:12px;color:var(--text2)}
.sic-bar{width:100%;height:3px;background:var(--surface3);border-radius:2px;margin-top:6px;overflow:hidden}
.sic-bar-fill{height:100%;border-radius:2px;background:var(--blue-mid);transition:width .5s}
.sic-bar-fill.level-low{background:var(--amber)}
.sic-bar-fill.level-critical{background:var(--red)}
.sic-right{text-align:right;flex-shrink:0}
.sic-qty{font-size:24px;font-weight:800;color:var(--text)}
.sic-qty.level-low{color:var(--amber)}
.sic-qty.level-critical{color:var(--red)}
.stock-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;margin-top:3px}
.badge-ok{background:var(--green-lt);color:var(--green)}
.badge-low{background:var(--amber-lt);color:var(--amber)}
.badge-critical{background:var(--red-lt);color:var(--red)}

/* ── DASHBOARD REG SUMMARY ── */
.reg-summary-card{background:var(--surface);border-radius:14px;padding:14px;box-shadow:var(--shadow);margin-bottom:8px}
.rsc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.rsc-client{font-size:14px;font-weight:700;color:var(--text)}
.rsc-date{font-size:11px;color:var(--text3)}
.rsc-fields{display:flex;flex-wrap:wrap;gap:8px}
.rsc-field{background:var(--surface2);border-radius:8px;padding:6px 10px;text-align:center;min-width:60px}
.rsc-val{font-size:18px;font-weight:800;color:var(--text)}
.rsc-lbl{font-size:10px;color:var(--text2);margin-top:2px}

/* ── ACTIVITY ── */
.activity-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.activity-item:last-child{border-bottom:none}
.act-icon{width:36px;height:36px;border-radius:50%;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--blue-txt)}
.act-icon.reg-icon{background:var(--green-lt);color:var(--green)}
.act-icon svg{width:16px;height:16px}
.act-text{font-size:13px;color:var(--text);line-height:1.5}
.act-meta{font-size:11px;color:var(--text3);margin-top:2px}
.no-data{text-align:center;padding:30px 16px;color:var(--text3);font-size:14px;line-height:1.6}

/* ── ALERTS ── */
.alert-banner{background:var(--amber-lt);border-left:4px solid var(--amber);border-radius:0 12px 12px 0;padding:12px 14px;margin-bottom:12px;font-size:13px;color:var(--text);line-height:1.5}
.alert-banner.critical{background:var(--red-lt);border-left-color:var(--red)}
.stock-day-banner{background:linear-gradient(135deg,var(--green),#047857);border-radius:14px;padding:14px 16px;margin-bottom:12px;display:flex;align-items:center;gap:12px;color:#fff}
.sdb-text{font-size:14px;font-weight:700}
.sdb-sub{font-size:12px;opacity:.75;margin-top:2px}

/* ── LOG HERO ── */
.log-hero{background:linear-gradient(135deg,var(--blue-mid),var(--blue));border-radius:16px;padding:16px 18px;color:#fff;margin-bottom:14px;position:relative}
.log-hero-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.lh-lbl{font-size:10px;opacity:.7;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.lh-date{font-size:19px;font-weight:800;line-height:1.2}
.lh-hint{font-size:12px;opacity:.65}

/* ── DATE CHIP — native input styled as a pill button ── */
/* Works on all browsers/devices — no JS tricks, no overlays */
.date-chip-native{
  -webkit-appearance:none;
  appearance:none;
  border:none;
  outline:none;
  background:rgba(255,255,255,0.22);
  color:#fff;
  border-radius:20px;
  padding:7px 14px;
  font-size:12px;
  font-weight:600;
  font-family:inherit;
  cursor:pointer;
  flex-shrink:0;
  margin-top:4px;
  min-width:120px;
  text-align:center;
}
.date-chip-native::-webkit-calendar-picker-indicator{
  filter:invert(1);
  opacity:0.8;
  cursor:pointer;
}
.date-chip-native::-webkit-date-and-time-value{
  text-align:left;
}
.date-chip-native:active,.date-chip-native:focus{
  background:rgba(255,255,255,0.35);
  outline:none;
}


/* ── LOG ITEM CARDS ── */
.log-item-card{background:var(--surface);border-radius:14px;margin-bottom:10px;box-shadow:var(--shadow);overflow:hidden}
.lic-top{display:flex;justify-content:space-between;align-items:center;padding:14px 16px 8px}
.lic-name{font-size:15px;font-weight:700;color:var(--text)}
.lic-avail{font-size:12px;color:var(--text2);margin-top:3px}
.avail-num{font-weight:800;color:var(--text)}
.avail-num.low{color:var(--amber)}
.avail-num.critical{color:var(--red)}
.qty-row{display:flex;align-items:center;padding:4px 14px 14px;gap:0}
.qty-btn{width:48px;height:48px;border-radius:12px;background:var(--blue-lt);color:var(--blue-txt);font-size:26px;font-weight:300;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .1s;line-height:1;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.qty-btn:active{background:var(--blue-mid);color:#fff;transform:scale(.95)}
.qty-field{flex:1;text-align:center;font-size:24px;font-weight:800;color:var(--text);border:none;outline:none;background:none;padding:0 10px;-moz-appearance:textfield;min-width:0}
.qty-field::-webkit-outer-spin-button,.qty-field::-webkit-inner-spin-button{-webkit-appearance:none}

/* ── REGISTRATION FIELDS ── */
.reg-section-card{background:var(--surface);border-radius:14px;padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow)}
.reg-fields-card{background:var(--surface);border-radius:14px;padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow)}
.reg-field-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--border)}
.reg-field-row:last-child{border-bottom:none}
.reg-field-name{font-size:14px;font-weight:600;color:var(--text);flex:1}
.reg-field-input{width:80px;border:1.5px solid var(--border);border-radius:10px;padding:8px;text-align:center;font-size:18px;font-weight:800;color:var(--text);background:var(--surface);outline:none}
.reg-field-input:focus{border-color:var(--blue-mid)}

/* ── NOTES ── */
.notes-wrap{background:var(--surface);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow);margin-top:4px}
.field-textarea{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:10px 12px;resize:none;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s;line-height:1.5}
.field-textarea:focus{border-color:var(--blue-mid)}

/* ── STOCK COUNT ── */
.stock-count-card{background:var(--surface);border-radius:14px;padding:15px 16px;display:flex;align-items:center;gap:12px;margin-bottom:10px;box-shadow:var(--shadow)}
.scc-info{flex:1}
.scc-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px}
.scc-prev{font-size:12px;color:var(--text2)}
.scc-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.scc-input{width:84px;text-align:center;border:2px solid var(--border);border-radius:10px;padding:9px;font-size:17px;font-weight:800;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s}
.scc-input:focus{border-color:var(--blue-mid)}
.var-tag{font-size:11px;font-weight:800;padding:2px 9px;border-radius:8px}
.var-pos{background:var(--green-lt);color:var(--green)}
.var-neg{background:var(--red-lt);color:var(--red)}
.var-zero{background:var(--surface3);color:var(--text3)}

/* ── REPORTS ── */
.report-tabs{display:flex;gap:6px;margin-bottom:12px}
.rtab{flex:1;padding:11px;border-radius:12px;font-size:14px;font-weight:700;color:var(--text2);background:var(--surface);border:2px solid var(--border)}
.rtab.active{background:var(--blue-mid);color:#fff;border-color:var(--blue-mid)}
.rtype-row{display:flex;gap:8px;margin-bottom:12px}
.rtype-btn{flex:1;padding:10px 6px;border-radius:10px;font-size:13px;font-weight:600;color:var(--text2);background:var(--surface);border:1.5px solid var(--border)}
.rtype-btn.active{background:var(--blue-mid);color:#fff;border-color:var(--blue-mid)}
.custom-range-box{background:var(--surface);border-radius:14px;padding:14px;margin-bottom:12px;box-shadow:var(--shadow)}
.btn-block-primary{width:100%;padding:15px;background:var(--blue-mid);color:#fff;border-radius:14px;font-size:15px;font-weight:700;margin-bottom:14px}
.btn-block-primary:active{background:var(--blue)}

/* ── REPORT OUTPUT ── */
.report-card{background:var(--surface);border-radius:16px;padding:18px;box-shadow:var(--shadow);margin-bottom:12px}
.report-title{font-size:17px;font-weight:800;color:var(--text);margin-bottom:4px}
.report-meta{font-size:12px;color:var(--text2);margin-bottom:14px;line-height:1.6}
.rpt-summary{display:flex;gap:10px;margin-bottom:16px}
.rpt-metric{flex:1;background:var(--blue-lt);border-radius:12px;padding:12px;text-align:center}
.rpt-metric-val{font-size:24px;font-weight:800;color:var(--blue-txt)}
.rpt-metric-lbl{font-size:10px;color:var(--blue-txt);opacity:.8;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
.rpt-sec-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin:14px 0 8px;border-top:1px solid var(--border);padding-top:12px}
.rpt-table{width:100%;border-collapse:collapse;font-size:13px}
.rpt-table th{color:var(--text3);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:5px 0;border-bottom:1px solid var(--border);text-align:left}
.rpt-table td{padding:8px 0;border-bottom:1px solid var(--surface3);color:var(--text);vertical-align:top}
.rpt-table tr:last-child td{border-bottom:none}
.rpt-gen-note{font-size:10px;color:var(--text3);text-align:right;margin-top:14px}

/* ── SHARE ROW ── */
.share-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}
.share-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 15px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:opacity .15s;-webkit-tap-highlight-color:transparent}
.share-btn:active{opacity:.75}
.share-wa{background:#25d366;color:#fff}
.share-txt{background:var(--surface2);color:var(--text);border:1.5px solid var(--border)}
.share-pdf{background:var(--red-lt);color:var(--red);border:1.5px solid rgba(220,38,38,.2)}

/* ── SETTINGS ── */
.settings-card{background:var(--surface);border-radius:16px;padding:18px;margin-bottom:12px;box-shadow:var(--shadow)}
.sc-title{font-size:12px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px}
.settings-hint{font-size:13px;color:var(--text2);margin-bottom:12px;line-height:1.6}
.danger-zone{border:1.5px solid rgba(220,38,38,.2)}
.dev-card{border:1.5px solid rgba(251,191,36,.4);background:var(--surface)}
.dev-badge{background:var(--amber-lt);color:var(--amber);font-size:10px;font-weight:700;padding:2px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.5px;margin-left:6px}
.dev-unlock-row{display:flex;justify-content:flex-end;margin-bottom:12px}
.dev-unlock-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text3);padding:8px 12px;border-radius:8px;background:var(--surface2);border:1px solid var(--border)}
.dev-unlock-btn:active{background:var(--surface3)}
.settings-item-row{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--border)}
.settings-item-row:last-child{border-bottom:none}
.si-name{font-size:14px;font-weight:600;color:var(--text)}
.si-detail{font-size:12px;color:var(--text2);margin-top:2px}
.add-item-sec{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.holiday-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border)}
.holiday-row:last-child{border-bottom:none}
.theme-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.theme-row-lbl{font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px}
.toggle-sw{width:50px;height:28px;background:var(--surface3);border-radius:14px;position:relative;cursor:pointer;border:none;flex-shrink:0;transition:background .25s}
.toggle-sw.on{background:var(--blue-mid)}
.toggle-knob{position:absolute;top:4px;left:4px;width:20px;height:20px;border-radius:50%;background:#fff;transition:left .25s;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.toggle-sw.on .toggle-knob{left:26px}
.about-block{text-align:center;background:var(--surface);border-radius:16px;padding:28px 16px;margin-bottom:12px;box-shadow:var(--shadow)}
.about-name{font-size:22px;font-weight:800;color:var(--blue-txt);margin:10px 0 4px}
.about-ver{font-size:13px;color:var(--text3);margin-bottom:14px}
.about-dev{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}
.about-copy{font-size:12px;color:var(--text3)}

/* ── PROFILE MODAL ── */
.profile-av-xl{width:76px;height:76px;border-radius:50%;background:var(--blue-lt);color:var(--blue-txt);font-size:28px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto;border:3px solid var(--blue-mid)}
.profile-site-txt{font-size:13px;color:var(--text2);text-align:center;margin-top:5px}
.profile-meta-txt{font-size:12px;color:var(--text3);text-align:center;margin-top:3px}

/* ── FORMS ── */
.form-group{margin-bottom:13px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field-label{display:block;font-size:11px;font-weight:700;color:var(--text2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}
.hint-text{font-size:10px;font-weight:400;color:var(--text3);text-transform:none;letter-spacing:0}
.field-input{width:100%;border:1.5px solid var(--border);border-radius:12px;padding:12px 14px;font-size:16px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s;-webkit-appearance:none}
.field-input:focus{border-color:var(--blue-mid)}

/* ── BUTTONS ── */
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;background:var(--blue-mid);color:#fff;border-radius:12px;font-size:14px;font-weight:700}
.btn-primary:active{background:var(--blue)}
.btn-primary-lg{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:15px;background:var(--blue-mid);color:#fff;border-radius:14px;font-size:15px;font-weight:700}
.btn-primary-lg:active{background:var(--blue)}
.btn-success-lg{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:15px;background:var(--green);color:#fff;border-radius:14px;font-size:15px;font-weight:700}
.btn-success-lg:active{opacity:.85}
.btn-ghost{padding:13px 20px;color:var(--text2);border-radius:14px;font-size:14px;font-weight:600;background:var(--surface2);border:1.5px solid var(--border)}
.btn-ghost:active{background:var(--surface3)}
.btn-danger{padding:10px 16px;background:var(--red);color:#fff;border-radius:10px;font-size:13px;font-weight:700}
.btn-danger:active{opacity:.8}
.btn-sm{padding:9px 16px;font-size:13px}
.btn-icon-del{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--red-lt);color:var(--red);flex-shrink:0}

/* ── BOTTOM BAR ── */
.bottom-bar{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:12px 14px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0));display:flex;gap:10px;z-index:50;box-shadow:0 -4px 20px rgba(0,0,0,.06)}
.fab-spacer{height:100px}

/* ── TOAST ── */
.toast{position:fixed;bottom:calc(90px + env(safe-area-inset-bottom,0));left:50%;transform:translateX(-50%) translateY(6px);background:#1a1a2e;color:#fff;padding:11px 22px;border-radius:24px;font-size:14px;font-weight:600;opacity:0;transition:all .25s;pointer-events:none;z-index:9999;max-width:88vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
[data-theme="dark"] .toast{background:#e8eaf6;color:#0f1117}

/* ── MODAL ── */
.modal-overlay{display:flex;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:500;align-items:center;justify-content:center;padding:20px}
.modal-overlay.hidden{display:none}
.modal-box{background:var(--surface);border-radius:20px;padding:22px;width:100%;max-width:370px;max-height:90vh;overflow-y:auto}
.modal-title{font-size:17px;font-weight:800;color:var(--text);margin-bottom:10px}
.modal-body{font-size:14px;color:var(--text2);line-height:1.6;margin-bottom:16px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end}

/* ── PRINT ── */
@media print{
  /* Hide everything except the report output */
  body > *:not(#app){ display:none!important }
  .header,.drawer,.drawer-overlay,.bottom-bar,.share-row,.report-tabs,.rtype-row,
  .btn-block-primary,#customRangeBox,.dev-unlock-row,.dev-card,.nav-item,
  .drawer-foot,.quick-actions,.sec-hdr,.week-hero,.metrics-grid,
  .week-progress-bar,.fab,#fabWrap,.toast,.modal-overlay,
  #page-dashboard,#page-log,#page-reg,#page-stock,#page-insights,#page-settings,
  .insights-hero,.export-card,.chart-card,.forecast-cards,
  .empty-state-card{ display:none!important }

  /* Show ONLY the reports page and only the output card */
  #page-reports{ display:block!important; padding:0!important }
  #reportOutput{ display:block!important }

  /* Reset layout so there are zero blank pages */
  html,body{ height:auto!important; overflow:visible!important;
    background:#fff!important; color:#000!important; margin:0!important; padding:0!important }
  .app{ height:auto!important; overflow:visible!important; display:block!important }
  .main-content{ overflow:visible!important; height:auto!important }
  .page{ display:none!important }
  #page-reports{ display:block!important }

  .report-card{ box-shadow:none!important; border:1px solid #ccc;
    page-break-inside:avoid; margin:0!important; padding:12pt!important }
  .rpt-metric{ background:#e8f0fe!important;
    -webkit-print-color-adjust:exact; print-color-adjust:exact }
  .rpt-table{ width:100%; font-size:10pt }
  @page{ margin:15mm; size:A4 }
}

/* ── DATE CHIP — transparent input overlays the visible button ── */
.date-chip-wrap{
  position:relative;
  flex-shrink:0;
  margin-top:4px;
}
.date-chip-label{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,0.22);
  color:#fff;border-radius:20px;padding:7px 14px;
  font-size:12px;font-weight:600;font-family:inherit;
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  user-select:none;white-space:nowrap;
  pointer-events:none; /* clicks pass through to the overlay input */
}
/* The real date input — fully transparent, sits on top, triggers native picker */
.date-input-overlay{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor:pointer;
  font-size:16px; /* prevents iOS zoom */
  border:none;
  background:transparent;
  -webkit-appearance:none;
  appearance:none;
  z-index:3;
  color:transparent;
}

/* ── FAB ── */
.fab{
  position:fixed;bottom:calc(88px + env(safe-area-inset-bottom,0));right:18px;
  width:54px;height:54px;border-radius:50%;
  background:var(--blue-mid);color:#fff;
  box-shadow:0 4px 16px rgba(13,71,161,.45);
  display:flex;align-items:center;justify-content:center;
  z-index:49;transition:transform .15s,box-shadow .15s;
  border:none;cursor:pointer;
}
.fab:active{transform:scale(.92);box-shadow:0 2px 8px rgba(13,71,161,.3)}
/* Speed-dial backdrop */
.fab-backdrop{
  position:fixed;inset:0;z-index:48;
  background:rgba(0,0,0,0.4);
  backdrop-filter:blur(2px);
}
/* Speed-dial menu */
.fab-menu{
  position:fixed;
  bottom:calc(156px + env(safe-area-inset-bottom,0));
  right:14px;z-index:49;
  display:flex;flex-direction:column;gap:14px;align-items:flex-end;
}
.fab-option{
  display:flex;align-items:center;gap:12px;
  background:none;border:none;cursor:pointer;padding:0;
}
.fab-option:active .fab-opt-icon{transform:scale(0.93)}
.fab-opt-label{
  background:var(--surface);color:var(--text);
  font-size:14px;font-weight:700;
  padding:9px 16px;border-radius:24px;
  box-shadow:0 3px 14px rgba(0,0,0,0.22);
  white-space:nowrap;
}
[data-theme="dark"] .fab-opt-label{background:var(--surface2);}
.fab-opt-icon{
  width:50px;height:50px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;flex-shrink:0;
  box-shadow:0 3px 12px rgba(0,0,0,0.28);
  transition:transform 0.15s;
}

/* ── INSIGHTS PAGE ── */
.insights-hero{background:linear-gradient(135deg,#1a237e,var(--blue-mid));border-radius:16px;padding:18px;color:#fff;margin-bottom:16px}
.ih-title{font-size:19px;font-weight:800;margin-bottom:4px}
.ih-sub{font-size:13px;opacity:.7}

/* Forecast cards */
.forecast-card{background:var(--surface);border-radius:14px;padding:14px 16px;margin-bottom:8px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}
.fc-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.fc-icon.ok{background:var(--green-lt)}
.fc-icon.warn{background:var(--amber-lt)}
.fc-icon.critical{background:var(--red-lt)}
.fc-info{flex:1;min-width:0}
.fc-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:2px}
.fc-detail{font-size:12px;color:var(--text2);line-height:1.5}
.fc-days{font-size:22px;font-weight:800;flex-shrink:0;text-align:right}
.fc-days.ok{color:var(--green)}
.fc-days.warn{color:var(--amber)}
.fc-days.critical{color:var(--red)}
.fc-days-lbl{font-size:10px;color:var(--text3);text-align:right}

/* Chart */
.chart-card{background:var(--surface);border-radius:14px;padding:16px;box-shadow:var(--shadow);margin-bottom:8px;position:relative}

/* Top items */
.top-item-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.top-item-row:last-child{border-bottom:none}
.top-item-rank{width:26px;height:26px;border-radius:50%;background:var(--blue-lt);color:var(--blue-txt);font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.top-item-name{flex:1;font-size:14px;font-weight:600;color:var(--text)}
.top-item-bar-wrap{flex:2;height:6px;background:var(--surface3);border-radius:3px;overflow:hidden}
.top-item-bar{height:100%;border-radius:3px;background:var(--blue-mid);transition:width .5s}
.top-item-qty{font-size:14px;font-weight:800;color:var(--text);min-width:36px;text-align:right}

/* Reorder alerts */
.reorder-card{background:var(--surface);border-radius:14px;padding:14px 16px;margin-bottom:8px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px}
.reorder-info{flex:1;min-width:0}
.reorder-name{font-size:14px;font-weight:700;color:var(--text);margin-bottom:2px}
.reorder-detail{font-size:12px;color:var(--text2)}
.reorder-wa{background:#25d366;color:#fff;border-radius:10px;padding:8px 14px;font-size:12px;font-weight:700;display:flex;align-items:center;gap:5px;flex-shrink:0}
.reorder-wa:active{opacity:.8}

/* Export */
.export-card{background:var(--surface);border-radius:14px;padding:16px;box-shadow:var(--shadow);margin-bottom:8px}
.export-desc{font-size:13px;color:var(--text2);line-height:1.6}

/* ── STREAK BADGE on dashboard ── */
.streak-banner{background:linear-gradient(135deg,#ff6f00,#ffa000);border-radius:14px;padding:13px 16px;margin-bottom:12px;color:#fff;display:flex;align-items:center;gap:12px}
.streak-icon{font-size:24px}
.streak-text{font-size:13px;font-weight:700}
.streak-sub{font-size:11px;opacity:.8;margin-top:2px}

/* ── QUICK ACTIONS ROW ── */
.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:18px}
.qa-btn{background:var(--surface);border-radius:14px;padding:12px 4px 10px;display:flex;flex-direction:column;align-items:center;gap:6px;font-size:11px;font-weight:700;color:var(--text2);box-shadow:var(--shadow);transition:transform .1s,background .15s;text-transform:uppercase;letter-spacing:.3px}
.qa-btn svg{color:var(--blue-txt)}
.qa-btn:active{transform:scale(.94);background:var(--blue-lt);color:var(--blue-txt)}

/* ── SEARCH INPUT ── */
.search-input{border:1.5px solid var(--border);border-radius:20px;padding:5px 12px;font-size:13px;color:var(--text);background:var(--surface);outline:none;width:130px;transition:border-color .15s,width .2s}
.search-input:focus{border-color:var(--blue-mid);width:160px}

/* ── WEEK HERO ADDITIONS ── */
.wh-streak{font-size:11px;color:rgba(255,255,255,.75);margin-top:8px;width:100%;text-align:center;padding-top:8px;border-top:1px solid rgba(255,255,255,.2)}
.week-hero{cursor:pointer}
.week-hero:active{opacity:.9}

/* ── WEEK PROGRESS BAR ── */
.week-progress-bar{background:var(--surface);border-radius:14px;padding:14px 16px;margin-bottom:14px;box-shadow:var(--shadow)}
.wpb-label{font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}
.wpb-track{width:100%;height:8px;background:var(--surface3);border-radius:4px;overflow:hidden;margin-bottom:8px}
.wpb-fill{height:100%;background:linear-gradient(90deg,var(--blue-mid),var(--green));border-radius:4px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.wpb-days{display:flex;gap:4px}
.wpb-day{flex:1;text-align:center}
.wpb-day-dot{width:28px;height:28px;border-radius:50%;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text3);margin:0 auto 3px;transition:background .2s}
.wpb-day-dot.logged{background:var(--green);color:#fff}
.wpb-day-dot.today{background:var(--blue-mid);color:#fff;box-shadow:0 0 0 3px rgba(21,101,192,.25)}
.wpb-day-dot.missed{background:var(--red-lt);color:var(--red)}
.wpb-day-dot.future{background:var(--surface3);color:var(--text3)}
.wpb-day-lbl{font-size:9px;color:var(--text3);font-weight:600}

/* ── WEEK PROGRESS MODAL ── */
.wp-item-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border)}
.wp-item-row:last-child{border-bottom:none}
.wp-item-name{font-size:13px;font-weight:600;color:var(--text)}
.wp-item-used{font-size:13px;font-weight:800;color:var(--blue-txt)}
.wp-used-lbl{font-size:11px;color:var(--text3);margin-left:2px}

/* ── REORDER ALERT CARD ── */
.reorder-card{background:var(--amber-lt);border:1.5px solid var(--amber);border-radius:14px;padding:14px 16px;margin-bottom:10px}
.reorder-title{font-size:13px;font-weight:800;color:var(--amber);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.reorder-item{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;color:var(--text);border-bottom:1px solid rgba(217,119,6,.15)}
.reorder-item:last-child{border-bottom:none}
.reorder-qty{font-weight:800;color:var(--red)}
.reorder-share-btn{margin-top:10px;display:flex;align-items:center;gap:6px;background:#25d366;color:#fff;border-radius:10px;padding:8px 14px;font-size:13px;font-weight:700;border:none;cursor:pointer}

/* ── TREND MINI CHART ── */
.trend-wrap{display:flex;align-items:flex-end;gap:2px;height:24px;margin-top:4px}
.trend-bar{flex:1;background:var(--blue-lt);border-radius:2px 2px 0 0;min-height:2px;transition:height .4s}
.trend-bar.today{background:var(--blue-mid)}

/* ── LOG ITEM SWIPE/DELETE ── */
.log-entry-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--text)}
.log-entry-row:last-child{border-bottom:none}
.log-entry-info{flex:1}
.log-entry-name{font-weight:600}
.log-entry-meta{font-size:11px;color:var(--text3);margin-top:1px}

/* ── STREAK BADGE ── */
.streak-badge{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:800}

/* ── TODAY SUMMARY SHEET ── */
.summary-sheet{background:var(--surface);border-radius:16px;padding:16px;margin-bottom:10px;box-shadow:var(--shadow)}
.summary-sheet-title{font-size:13px;font-weight:800;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}
.summary-item-line{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.summary-item-line:last-child{border-bottom:none}
.summary-item-name{color:var(--text)}
.summary-item-val{font-weight:800;color:var(--text)}
.summary-item-val.used{color:var(--red)}
.summary-total{display:flex;justify-content:space-between;padding:10px 0 0;font-size:14px;font-weight:800;color:var(--text);border-top:2px solid var(--border);margin-top:4px}

/* ── EMPTY STATE CARD ── */
.empty-state-card{
  background:var(--surface);border-radius:16px;padding:28px 20px;
  text-align:center;box-shadow:var(--card-shadow);margin-bottom:12px;
}
.es-icon{font-size:40px;margin-bottom:10px}
.es-title{font-size:16px;font-weight:800;color:var(--text);margin-bottom:8px}
.es-sub{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:18px}
.es-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* ── WEEK SUMMARY BAR ── */
.week-bar{
  background:var(--surface);border-radius:14px;
  display:flex;align-items:stretch;
  box-shadow:var(--card-shadow);
  margin-bottom:14px;overflow:hidden;
}
.wb-item{
  flex:1;padding:14px 6px;text-align:center;
}
.wb-val{
  font-size:22px;font-weight:800;color:var(--blue-txt);
  line-height:1;margin-bottom:4px;
}
.wb-lbl{
  font-size:9px;color:var(--text3);
  text-transform:uppercase;letter-spacing:0.4px;line-height:1.4;
}
.wb-divider{
  width:1px;background:var(--border);
  margin:10px 0;flex-shrink:0;
}

/* ── PAGE BACK BAR ── */
.page-back-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 0 4px;margin-bottom:2px;
}
.back-btn{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--surface2);color:var(--text2);
  border:1.5px solid var(--border);border-radius:20px;
  padding:7px 14px;font-size:13px;font-weight:600;
  cursor:pointer;transition:all 0.15s;
}
.back-btn:active{background:var(--surface3);}
.clear-day-btn{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--red-lt);color:var(--red);
  border:1.5px solid transparent;border-radius:20px;
  padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;
}
.clear-day-btn:active{opacity:0.75;}

/* ── ANIMATED STOCK COUNT BANNER ── */
.animated-banner{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,#1b5e20,#2e7d32,#43a047)!important;
  border-radius:16px;padding:18px 16px;
  display:flex;align-items:center;gap:14px;
  margin-bottom:12px;
  box-shadow:0 4px 20px rgba(46,125,50,0.45);
  animation:bannerPop 0.5s cubic-bezier(0.175,0.885,0.32,1.275);
}
@keyframes bannerPop{
  from{transform:scale(0.92);opacity:0}
  to{transform:scale(1);opacity:1}
}
.sdb-emoji{font-size:32px;animation:wiggle 1.5s ease-in-out infinite;flex-shrink:0}
@keyframes wiggle{
  0%,100%{transform:rotate(0)}
  20%{transform:rotate(-12deg)}
  40%{transform:rotate(12deg)}
  60%{transform:rotate(-8deg)}
  80%{transform:rotate(8deg)}
}
.sdb-body{flex:1}
.sdb-text{color:#fff;font-size:17px;font-weight:800;letter-spacing:0.2px}
.sdb-sub{color:rgba(255,255,255,0.8);font-size:12px;margin-top:3px}
/* Floating particles */
.sdb-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.sdb-particles span{
  position:absolute;display:block;border-radius:50%;
  background:rgba(255,255,255,0.15);animation:float 3s infinite ease-in-out;
}
.sdb-particles span:nth-child(1){width:40px;height:40px;top:-10px;left:10%;animation-delay:0s}
.sdb-particles span:nth-child(2){width:20px;height:20px;top:50%;left:75%;animation-delay:0.5s}
.sdb-particles span:nth-child(3){width:30px;height:30px;bottom:-5px;left:55%;animation-delay:1s}
.sdb-particles span:nth-child(4){width:15px;height:15px;top:20%;left:88%;animation-delay:1.5s}
.sdb-particles span:nth-child(5){width:25px;height:25px;bottom:5px;left:25%;animation-delay:2s}
@keyframes float{
  0%,100%{transform:translateY(0) scale(1);opacity:0.6}
  50%{transform:translateY(-12px) scale(1.1);opacity:0.9}
}
.sdb-pulse-ring{
  position:absolute;right:16px;top:50%;transform:translateY(-50%);
  width:36px;height:36px;border-radius:50%;
  border:3px solid rgba(255,255,255,0.5);
  animation:ringPulse 1.5s ease-out infinite;
}
@keyframes ringPulse{
  0%{transform:translateY(-50%) scale(0.8);opacity:1}
  100%{transform:translateY(-50%) scale(1.6);opacity:0}
}

/* ── HISTORY TABLE ── */
.hist-scroll{
  overflow-x:auto;border-radius:14px;
  box-shadow:var(--card-shadow);
  background:var(--surface);
  margin-bottom:8px;
}
.hist-table{
  width:100%;border-collapse:collapse;font-size:12px;min-width:420px;
}
.hist-table thead th{
  background:var(--surface2);color:var(--text3);
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.6px;padding:10px 12px;
  border-bottom:1px solid var(--border);text-align:left;
  position:sticky;top:0;
}
.hist-row td{
  padding:10px 12px;border-bottom:1px solid var(--surface3);
  vertical-align:top;color:var(--text);
}
.hist-row:last-child td{border-bottom:none}
.hist-row:hover td{background:var(--surface2)}
.hist-date{white-space:nowrap;font-weight:600;font-size:11px;color:var(--text2)}
.hist-user{font-weight:600;white-space:nowrap}
.hist-detail{color:var(--text2);line-height:1.5;max-width:220px}
.hist-total{font-weight:800;text-align:right;white-space:nowrap}
.hist-badge{
  display:inline-block;padding:2px 8px;border-radius:8px;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.4px;
}
.hist-badge-stock{background:var(--blue-lt);color:var(--blue-txt)}
.hist-badge-reg{background:var(--green-lt);color:var(--green)}

/* ── ITEM EMOJI ICONS ── */
.sic-icon{font-size:16px;display:flex;align-items:center;justify-content:center}

/* ── QTY PLUS BUTTON COLOUR ── */
.qty-plus{background:var(--blue-mid)!important;color:#fff!important;border-color:var(--blue-mid)!important}
.qty-plus:active{background:var(--blue)!important}

/* ── REG FIELD ROW WITH QTY BUTTONS ── */
.reg-field-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 0;border-bottom:1px solid var(--border);gap:10px;
}
.reg-field-row:last-child{border-bottom:none}
.reg-field-name{font-size:14px;font-weight:600;color:var(--text);flex:1}

/* ── ITEM ACTION BUTTONS (edit + delete) ── */
.item-action-btns{display:flex;align-items:center;gap:6px;flex-shrink:0}
.btn-icon-edit{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:var(--blue-lt);color:var(--blue-txt);border:none;cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent}
.btn-icon-edit:active{background:var(--blue-mid);color:#fff}

/* ── SINGLE-BUTTON BOTTOM BAR ── */
.bottom-bar-single{gap:0}
.bottom-bar-single .btn-primary-lg{border-radius:14px}
