﻿@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');
:root{
  --bg:#0a0a0a; --surface:#161616; --surface2:#242424; --border:#2c2c2c;
  --text:#f4f4f5; --muted:#a3a3a3; --primary:#f47920; --primary-d:#d4640f;
  --accent:#ff9d3c; --warn:#f59e0b; --danger:#ef4444; --radius:14px;
  --font:'Plus Jakarta Sans',system-ui,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:.1px;line-height:1.5}
a{color:var(--accent);text-decoration:none}
h1,h2,h3,h4{letter-spacing:-.2px}
.layout{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{width:240px;background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;
  transition:transform .25s ease;z-index:30}
.brand{padding:16px 14px 14px;font-weight:700;font-size:17px;display:flex;gap:10px;align-items:center;
  border-bottom:1px solid var(--border)}
.brand img{height:46px;width:auto;display:block}
.brand .bt{line-height:1.1}
.brand small{display:block;font-weight:400;font-size:10px;color:var(--muted);margin-top:2px}
.nav{padding:6px}
.nav a{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;color:var(--text);margin:2px 0}
.nav a:hover{background:var(--surface2)}
.nav a.active{background:var(--primary);color:#000;font-weight:600}
.nav a svg{width:18px;height:18px;flex:none;opacity:.95}
.btn svg{width:16px;height:16px}
.btn.sm svg{width:14px;height:14px}
.toggle-btn svg,.cam-btn svg{width:20px;height:20px;vertical-align:middle}
h3 svg{width:18px;height:18px;vertical-align:-3px;color:var(--primary)}
.svg-mid svg{vertical-align:middle}
.nav .section{color:var(--primary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:14px 14px 4px;opacity:.85}
.main{flex:1;margin-left:240px;display:flex;flex-direction:column;transition:margin-left .25s ease}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;gap:12px;
  background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}
.toggle-btn{background:var(--surface2);color:var(--primary);border:1px solid var(--border);
  width:40px;height:38px;border-radius:9px;cursor:pointer;font-size:18px;line-height:1;flex:none}
.toggle-btn:hover{background:var(--primary);color:#000}
/* Sidebar disembunyikan ke samping */
body.sidebar-collapsed .sidebar{transform:translateX(-100%)}
body.sidebar-collapsed .main{margin-left:0}
.sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:25;display:none}
@media(max-width:820px){
  .main{margin-left:0 !important}
  body:not(.sidebar-collapsed) .sidebar-backdrop{display:block}
}
.topbar .user{display:flex;align-items:center;gap:12px;color:var(--muted)}
/* Tombol switch Mode Toko <-> Event */
.mode-switch{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-weight:700;font-size:13px;
  background:var(--surface2);color:var(--text);border:1px solid var(--border);padding:7px 12px;border-radius:30px}
.mode-switch svg{width:16px;height:16px}
.mode-switch .ms-track{width:34px;height:18px;border-radius:20px;background:#3f3f46;position:relative;transition:.2s;flex:none}
.mode-switch .ms-dot{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:.2s}
.mode-switch.on{background:#7c1d1d;color:#fff;border-color:#dc2626}
.mode-switch.on .ms-track{background:#dc2626}
.mode-switch.on .ms-dot{left:18px}
@media(max-width:680px){.mode-switch{font-size:0;padding:7px 10px;gap:0}.mode-switch svg{margin-right:6px}}
.content{padding:22px;flex:1}
.page-title{font-size:20px;margin:0 0 16px;font-weight:700}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:20px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.card .label{color:var(--muted);font-size:12px}
.card .value{font-size:22px;font-weight:700;margin-top:4px}
.card .sub{font-size:12px;color:var(--muted);margin-top:4px}
.card.green{border-left:4px solid var(--primary)}
.card.blue{border-left:4px solid var(--accent)}
.card.amber{border-left:4px solid var(--warn)}
.card.red{border-left:4px solid var(--danger)}

/* Panels */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:18px}
.panel h3{margin:0 0 14px;font-size:15px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:900px){.grid2,.grid3{grid-template-columns:1fr}}

/* Forms */
label{display:block;font-size:12px;color:var(--muted);margin:10px 0 4px}
input,select,textarea{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);
  border-radius:8px;color:var(--text);font-size:14px;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
/* ikon kalender/jam bawaan jadi PUTIH MURNI agar terlihat di latar gelap */
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator{
  filter:brightness(0) invert(1);opacity:.85;cursor:pointer}
input[type="date"]::-webkit-calendar-picker-indicator:hover,
input[type="time"]::-webkit-calendar-picker-indicator:hover,
input[type="datetime-local"]::-webkit-calendar-picker-indicator:hover{opacity:1}
input[type="date"],input[type="time"],input[type="datetime-local"]{color-scheme:dark}
.btn{display:inline-flex;align-items:center;gap:6px;background:var(--primary);color:#fff;border:0;
  padding:10px 16px;border-radius:8px;font-size:14px;cursor:pointer;font-weight:600}
.btn:hover{background:var(--primary-d)}
.btn.sec{background:var(--surface2)}.btn.sec:hover{background:#324158}
.btn.blue{background:var(--accent)}.btn.amber{background:var(--warn)}.btn.red{background:var(--danger)}
.btn.sm{padding:6px 10px;font-size:12px}
.btn:disabled{opacity:.65;cursor:not-allowed}
.spin{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:-2px}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}

/* Tables */
table{width:100%;border-collapse:collapse}
th,td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}
th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.4px}
tbody tr:hover{background:var(--surface2)}
.right{text-align:right}.center{text-align:center}
.table-wrap{overflow-x:auto}

/* Badges */
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600}
.badge.green{background:#064e3b;color:#34d399}
.badge.blue{background:#0c4a6e;color:#7dd3fc}
.badge.amber{background:#78350f;color:#fcd34d}
.badge.red{background:#7f1d1d;color:#fca5a5}
.badge.gray{background:#334155;color:#cbd5e1}

/* Flash */
.flash{padding:12px 16px;border-radius:10px;margin-bottom:16px}
.flash.success{background:#064e3b;border:1px solid var(--primary)}
.flash.error{background:#7f1d1d;border:1px solid var(--danger)}
.flash.info{background:#0c4a6e;border:1px solid var(--accent)}

/* POS layout */
.pos{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}
@media(max-width:1000px){.pos{grid-template-columns:1fr}}
/* ===== Penyesuaian mobile / tablet ===== */
.topbar{flex-wrap:wrap}
@media(max-width:760px){
  .content{padding:14px}
  .panel{overflow-x:auto}          /* tabel lebar bisa di-geser, tak jebol layar */
  .page-title{font-size:18px}
  .cards{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
  .btn{padding:10px 14px}          /* target sentuh lebih besar */
}
/* Tabel jadi kartu di layar kecil */
@media(max-width:680px){
  .content table thead{display:none}
  .content table,.content tbody,.content tr,.content td{display:block;width:auto}
  .content .table-wrap{overflow:visible}
  .content tbody tr{border:1px solid var(--border);border-radius:10px;margin-bottom:10px;padding:6px 12px;background:var(--bg)}
  .content tbody tr:hover{background:var(--bg)}
  .content td{display:flex;justify-content:space-between;align-items:center;gap:12px;border:0;padding:6px 0;text-align:right}
  .content td::before{content:attr(data-label);color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px;text-align:left;flex:none}
  .content td:not([data-label]){justify-content:flex-end}
}
@media(max-width:560px){
  .topbar{padding:10px 12px;gap:8px}
  .user span{font-size:12px}
  .brand img{height:38px}
  .cards{grid-template-columns:1fr 1fr}
  .grid2,.grid3{grid-template-columns:1fr !important}
}
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;max-height:62vh;overflow-y:auto}
.pcard{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px;cursor:pointer;text-align:center}
.pcard:hover{border-color:var(--primary)}
.pthumb{width:100%;height:62px;object-fit:cover;border-radius:6px;margin-bottom:4px;background:var(--surface2);display:block}
.pthumb.noimg{display:flex;align-items:center;justify-content:center;color:var(--muted)}
.pthumb.noimg svg{width:26px;height:26px}
.lthumb{width:34px;height:34px;object-fit:cover;border-radius:6px;flex:none;background:var(--surface2)}
.lthumb.noimg{display:inline-flex;align-items:center;justify-content:center;color:var(--muted)}
.lthumb.noimg svg{width:18px;height:18px}
.pcard .nm{font-size:13px;font-weight:600;margin:4px 0;min-height:34px}
.pcard .pr{color:var(--primary);font-weight:700}
.pcard .st{font-size:11px;color:var(--muted)}
.cart-item{display:flex;justify-content:space-between;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);align-items:center}
.qty-ctl{display:flex;align-items:center;gap:6px}
.qty-ctl button{width:26px;height:26px;border-radius:6px;border:1px solid var(--border);background:var(--surface2);color:#fff;cursor:pointer}
.totals .row{display:flex;justify-content:space-between;padding:4px 0}
.totals .grand{font-size:20px;font-weight:800;color:var(--primary);border-top:1px solid var(--border);padding-top:10px;margin-top:6px}

/* ---- POS polish ---- */
.pcard{transition:transform .12s ease, border-color .12s ease, box-shadow .12s ease}
.pcard:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.35)}
.pcard:active{transform:translateY(-1px) scale(.99)}
.search-wrap{position:relative;margin-top:10px}
.search-wrap .search-ic{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted);pointer-events:none}
.search-wrap input{padding-left:38px}
.cart-panel{position:sticky;top:78px;align-self:start}
.cart-badge{background:var(--primary);color:#fff;border-radius:20px;padding:1px 9px;font-size:12px;margin-left:6px;vertical-align:2px}
#cart{max-height:46vh;overflow-y:auto}
.cart-item .ci-x{background:none;border:0;color:var(--danger);cursor:pointer;font-size:14px;opacity:.7}
.cart-item .ci-x:hover{opacity:1}
.cart-item{animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* ---- Modal Pembayaran ---- */
.pay-ov{position:fixed;inset:0;background:rgba(0,0,0,.62);display:flex;align-items:center;justify-content:center;z-index:60;padding:16px;backdrop-filter:blur(2px)}
.pay-ov.hidden{display:none}
.pay-box{background:var(--surface);border:1px solid var(--border);border-radius:18px;width:100%;max-width:470px;max-height:94vh;
  display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.55);animation:popIn .18s ease}
@keyframes popIn{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}
.pay-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border)}
.pay-head h3{margin:0;font-size:18px}
.pay-x{background:none;border:0;color:var(--muted);cursor:pointer;padding:4px;border-radius:8px}
.pay-x:hover{background:var(--surface2);color:var(--text)}
.pay-body{padding:18px 22px;display:flex;flex-direction:column;gap:9px;overflow-y:auto}
.pay-body label{font-size:12px;color:var(--muted);margin:8px 0 2px;display:block}
.pay-body input,.pay-body select{width:100%}
.pay-row{display:flex;justify-content:space-between;align-items:center;font-size:15px}
.pay-row.grand{font-size:19px;font-weight:800;color:var(--primary);border-top:1px dashed var(--border);padding-top:12px;margin-top:4px}
.pay-list{flex:0 0 auto;max-height:180px;overflow-y:auto;border:1px solid var(--border);border-radius:10px;padding:6px 10px;background:var(--bg);display:flex;flex-direction:column;margin:4px 0}
.pay-list .pl-it{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;font-size:13px;padding:7px 0;border-bottom:1px solid var(--border)}
.pay-list .pl-it:last-child{border-bottom:0}
.pay-list .pl-it b{white-space:nowrap;color:var(--primary)}
.pay-list .pl-it small{color:var(--muted)}
.pay-list:empty{display:none}
.pay-list-title{font-size:12px;color:var(--muted);margin-top:4px}
.quick-cash{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.quick-cash button{flex:1;min-width:62px;background:var(--surface2);border:1px solid var(--border);color:var(--text);
  padding:10px;border-radius:10px;cursor:pointer;font-weight:700;transition:.12s}
.quick-cash button:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.pay-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border)}
.pay-foot .btn{min-width:120px;justify-content:center}

/* ---- Toast ---- */
.toast-wrap{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:90;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:#1f1f1f;color:#fff;border:1px solid var(--border);border-left:4px solid var(--primary);
  padding:12px 18px;border-radius:10px;font-size:14px;font-weight:600;box-shadow:0 10px 30px rgba(0,0,0,.45);animation:toastIn .2s ease}
.toast.success{border-left-color:#22c55e}
.toast.error{border-left-color:var(--danger)}
.toast.fade{animation:toastOut .3s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(14px)}}

/* Scanner kamera */
.cam-btn{flex:none;width:52px;background:var(--surface2);border:1px solid var(--border);color:var(--primary);
  border-radius:8px;font-size:20px;cursor:pointer}
.cam-btn:hover{background:var(--primary);color:#000}
.scan-overlay{position:fixed;inset:0;background:#0a0a0a;z-index:9999;display:flex;flex-direction:column;
  padding:16px;gap:12px}
.scan-overlay>*{width:100%;max-width:760px;margin-left:auto;margin-right:auto}
.scan-head{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:14px}
.scan-x{background:none;border:0;color:var(--danger);font-weight:700;cursor:pointer;font-size:14px}
.scan-video-wrap{flex:1;position:relative;display:flex;align-items:center;justify-content:center;
  overflow:hidden;border-radius:14px;background:#000}
.scan-video-wrap video{width:100%;height:100%;object-fit:cover}
.scan-frame{position:absolute;width:70%;max-width:420px;aspect-ratio:3/2;pointer-events:none}
.scan-frame .c{position:absolute;width:34px;height:34px;border:4px solid #fff}
.scan-frame .tl{top:0;left:0;border-right:0;border-bottom:0}
.scan-frame .tr{top:0;right:0;border-left:0;border-bottom:0}
.scan-frame .bl{bottom:0;left:0;border-right:0;border-top:0}
.scan-frame .br{bottom:0;right:0;border-left:0;border-top:0}
.scan-laser{position:absolute;left:6%;right:6%;top:50%;height:2px;background:var(--primary);
  box-shadow:0 0 10px 2px var(--primary);animation:laser 1.6s ease-in-out infinite}
@keyframes laser{0%{top:12%}50%{top:88%}100%{top:12%}}
.scan-status{display:flex;justify-content:space-between;align-items:center;background:var(--surface);
  border:1px solid var(--border);border-radius:10px;padding:12px 16px;color:var(--text)}
.scan-count{background:var(--primary);color:#000;border-radius:20px;padding:4px 14px;font-weight:700;font-size:13px}

/* Modal konfirmasi */
.confirm-ov{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}
.confirm-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px;width:100%;max-width:380px;box-shadow:0 20px 60px rgba(0,0,0,.55)}
.confirm-msg{font-size:15px;line-height:1.55;margin-bottom:14px}
.confirm-input{margin-bottom:14px}
.confirm-btns{display:flex;gap:8px;justify-content:flex-end}

/* Modal produk */
.modal2{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:90;display:none;
  align-items:flex-start;justify-content:center;overflow-y:auto;padding:28px 16px}
.modal2.show{display:flex}
.modal2-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:600px;margin:auto;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.modal2-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}
.modal2-x{background:none;border:0;color:var(--muted);font-size:26px;cursor:pointer;line-height:1}
.modal2-x:hover{color:var(--danger)}
.modal2-body{padding:20px}

.login-wrap{display:flex;min-height:100vh;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 0%,rgba(244,121,32,.18),transparent 55%),#0a0a0a}
.login-box{background:var(--surface);border:1px solid var(--border);border-top:4px solid var(--primary);
  padding:34px;border-radius:16px;width:min(360px,92vw);box-shadow:0 20px 60px rgba(0,0,0,.6)}
.muted{color:var(--muted)}
.hidden{display:none !important}
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--border);margin-bottom:16px}
.tabs a{padding:8px 14px;border-radius:8px 8px 0 0;color:var(--muted)}
.tabs a.active{background:var(--surface);color:var(--text);border:1px solid var(--border);border-bottom:none}

/* ===== Lightbox preview gambar ===== */
.zoomable{cursor:zoom-in;transition:filter .12s}
.zoomable:hover{filter:brightness(1.08)}
.zoom-ov{position:fixed;inset:0;background:rgba(0,0,0,.86);display:flex;align-items:center;justify-content:center;
  z-index:100;cursor:zoom-out;padding:24px;animation:fadeIn .15s ease;backdrop-filter:blur(3px)}
.zoom-ov img{max-width:92vw;max-height:88vh;border-radius:14px;box-shadow:0 24px 70px rgba(0,0,0,.6);animation:popIn .18s ease}
.zoom-x{position:fixed;top:18px;right:22px;background:rgba(255,255,255,.14);color:#fff;border:0;
  width:44px;height:44px;border-radius:50%;font-size:20px;cursor:pointer;line-height:1}
.zoom-x:hover{background:rgba(255,255,255,.28)}
.zoom-nav{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.14);color:#fff;border:0;
  width:50px;height:50px;border-radius:50%;font-size:30px;line-height:1;cursor:pointer;z-index:101;
  display:flex;align-items:center;justify-content:center;padding-bottom:4px}
.zoom-nav:hover{background:rgba(255,255,255,.3)}
.zoom-nav.prev{left:18px}.zoom-nav.next{right:18px}
.zoom-count{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);color:#fff;background:rgba(0,0,0,.55);
  padding:5px 14px;border-radius:20px;font-size:13px;font-weight:600;z-index:101}
@media(pointer:coarse){.zoom-nav{width:46px;height:46px;font-size:26px}}

/* ===== Elegance pass: panel, input, button, badge ===== */
.panel{box-shadow:0 1px 2px rgba(0,0,0,.25)}
input,select,textarea{font-family:var(--font)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 22%,transparent)}
.btn{transition:transform .1s ease, background .15s ease, box-shadow .15s ease;font-family:var(--font)}
.btn:hover{box-shadow:0 4px 14px rgba(0,0,0,.3)}
.btn:active{transform:translateY(1px)}
.card{transition:transform .12s ease, box-shadow .12s ease}
.card:hover{transform:translateY(-2px)}
.nav a{transition:background .12s ease, color .12s ease}
table tbody tr{transition:background .1s ease}
.content table tbody tr:hover{background:color-mix(in srgb,var(--surface2) 55%,transparent)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#333;border-radius:10px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:#444}

/* ===== Pencarian produk (dropdown) â€” dipakai grosir/online/transfer/penyesuaian ===== */
.pick-box{position:relative}
.pick-results{position:absolute;z-index:20;left:0;right:0;background:var(--surface);border:1px solid var(--border);
  border-radius:10px;margin-top:4px;max-height:300px;overflow-y:auto;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.pick-results .pick-it{padding:9px 12px;cursor:pointer;border-bottom:1px solid var(--border)}
.pick-results .pick-it:hover{background:var(--surface2)}
.pick-results .pick-it:last-child{border-bottom:0}
.pick-results .pick-it small{color:var(--muted)}

/* qty bisa diketik langsung di keranjang */
.qty-ctl input.qty-in{width:46px;text-align:center;padding:5px 2px;font-weight:700;font-size:14px;
  background:var(--surface2);border:1px solid var(--border);border-radius:7px;color:var(--text)}
.qty-ctl input.qty-in:focus{outline:none;border-color:var(--primary)}
.qty-ctl input.qty-in::-webkit-outer-spin-button,.qty-ctl input.qty-in::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

/* ===== Pemudah kasir ===== */
/* kilat scan */
.scan-flash{position:fixed;inset:0;z-index:95;pointer-events:none;animation:scanflash .28s ease}
.scan-flash.ok{background:rgba(34,197,94,.22)}
.scan-flash.no{background:rgba(239,68,68,.28)}
@keyframes scanflash{from{opacity:1}to{opacity:0}}
/* stok habis di grid kasir */
.pcard.habis{opacity:.5;position:relative}
.pcard.habis .pr,.pcard.habis .st{filter:grayscale(1)}
.habis-tag{position:absolute;top:6px;right:6px;background:var(--danger);color:#fff;font-size:9px;font-weight:800;padding:2px 6px;border-radius:6px;letter-spacing:.5px}
.hide-habis{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);cursor:pointer;margin:8px 0 0}
.hide-habis input{width:auto}
/* parkir transaksi */
#parkedBar{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:10px}
.park-chip{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:20px;
  padding:5px 10px;font-size:12px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.park-chip:hover{border-color:var(--primary)}
.park-chip span{color:var(--danger);font-weight:800}
/* diskon per item */
.disc-in{width:90px;text-align:right;padding:3px 6px;font-size:12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text)}
/* numpad layar */
.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px}
.numpad button{padding:12px;font-size:16px;font-weight:700;background:var(--surface2);border:1px solid var(--border);
  border-radius:9px;color:var(--text);cursor:pointer}
.numpad button:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.numpad button.np-act{background:#7f1d1d;color:#fff}

/* chip kategori di kasir */
.cat-chips{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0 2px}
.cat-chip{background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:20px;
  padding:5px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:.12s}
.cat-chip:hover{border-color:var(--primary);color:var(--text)}
.cat-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}

/* ===== Modal Struk in-page (POS) ===== */
.rcpt-ov{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:70;padding:16px;backdrop-filter:blur(2px)}
.rcpt-ov.hidden{display:none}
.rcpt-box{background:#fff;color:#000;border-radius:16px;width:100%;max-width:380px;max-height:94vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.5);animation:popIn .18s ease}
.rcpt-scroll{overflow-y:auto;padding:22px 22px 8px}
.rcpt-paper{font-family:'Courier New',monospace;color:#000}
.rc-head{text-align:center}
.rc-logo{max-width:165px;max-height:95px;width:auto;margin:0 auto 6px;display:block;object-fit:contain}
body.event-mode .rc-logo{max-width:172px;max-height:104px}
.rc-name{font-weight:800;font-size:16px}
.rc-sub{font-size:11px;color:#333;line-height:1.35}
.rc-line{border-top:1px dashed #999;margin:10px 0}
.rc-item{display:flex;justify-content:space-between;gap:10px;font-size:13px;margin-bottom:8px}
.rc-item small{color:#555}
.rc-item b{white-space:nowrap}
.rc-row{display:flex;justify-content:space-between;font-size:13px;margin:2px 0}
.rc-pay{width:100%;font-size:13px;border-collapse:collapse}
.rc-pay td{padding:1px 0}
.rc-pay td.r{text-align:right}
.rc-total{display:flex;justify-content:space-between;font-weight:800;font-size:17px;border-top:2px solid #000;margin-top:8px;padding-top:8px}
.rc-foot{text-align:center;font-size:12px;color:#444;margin-top:12px;font-style:italic}
.rc-wabox{padding:0 22px 10px}
.rc-wabox label{color:#333;font-size:12px;display:block}
.rc-wabox input{background:#f5f5f5;color:#000;border:1px solid #ccc}
.rcpt-foot{display:flex;gap:8px;padding:14px 22px;border-top:1px solid #e5e5e5}
.rcpt-foot .btn{flex:1;justify-content:center}

/* ===== Overlay struk generik (iframe receipt.php) ===== */
.rfrm-ov{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:80;padding:16px;backdrop-filter:blur(2px)}
.rfrm-box{background:#fff;border-radius:16px;width:100%;max-width:400px;max-height:94vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.55);animation:popIn .18s ease}
.rfrm-if{border:0;width:100%;flex:1;min-height:55vh;background:#fff}
.rfrm-wa{padding:8px 14px;display:flex;gap:8px;border-top:1px solid #eee;align-items:center}
.rfrm-wa input{flex:1;background:#f5f5f5;color:#000;border:1px solid #ccc}
.rfrm-foot{display:flex;gap:8px;padding:12px 14px;border-top:1px solid #eee}
.rfrm-foot .btn{flex:1;justify-content:center}

/* ===== Layar sentuh (HP/iPad): target ketuk lebih besar & nyaman ===== */
@media (pointer:coarse){
  .btn{min-height:42px}
  .btn.sm{min-height:38px;padding:8px 12px}
  input,select,textarea{min-height:44px;font-size:16px} /* 16px: cegah auto-zoom iOS saat fokus */
  .nav a{padding:12px 14px}
  .toggle-btn{width:44px;height:44px}
  .pcard{padding:14px 10px}
  .cat-chip{min-height:38px;padding:8px 14px}
  td .btn.sm{margin:2px 0}
}

/* Tabel "Per Metode Bayar" tampil besar seperti dashboard */
.metode-besar{width:100%;border-collapse:collapse}
.metode-besar th{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);
  padding:8px 6px;border-bottom:1px solid var(--border)}
.metode-besar th.right,.metode-besar td.right{text-align:right}
.metode-besar td{font-size:22px;font-weight:700;padding:14px 6px;border-bottom:1px solid var(--primary)}
.metode-besar td.metode-nama{text-transform:capitalize;color:var(--text)}
.metode-besar tr:last-child td{border-bottom:1px solid var(--border)}
