:root{--brand-50:#ecfdf5;--brand-100:#d1fae5;--brand-600:#0c7a5e;--brand-700:#0a6650;--brand-800:#0a5240;--bg:#f6f4ef;--surface:#fff;--surface-2:#fbfaf7;--border:#e8e3da;--border-strong:#d8d2c6;--ink:#1f1b16;--ink-2:#4a443c;--muted:#8a8178;--danger:#b42318;--danger-bg:#fef3f2;--warn:#b54708;--warn-bg:#fffaeb;--ok:#067647;--ok-bg:#ecfdf3;--accent:#b45309;--radius:12px;--radius-sm:9px;--radius-lg:16px;--shadow-sm:0 1px 2px #1c19170f;--shadow:0 4px 14px #1c191714;--shadow-lg:0 18px 50px #1c19172e;--ring:0 0 0 3px #0c7a5e2e;--sans:"Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-size:15px;line-height:1.5}h1,h2,h3{letter-spacing:-.02em;margin:0;font-weight:650}h1{font-size:1.5rem}h2{font-size:1.15rem}a{color:inherit;text-decoration:none}.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.muted{color:var(--muted)}.error{color:var(--danger);font-size:.88rem}.center{place-items:center;min-height:100vh;padding:1rem;display:grid}.stack{flex-direction:column;gap:.75rem;display:flex}.row{align-items:center;gap:.6rem;display:flex}.between{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.spacer{flex:1}.btn{--bg:var(--surface);--fg:var(--ink);--bd:var(--border-strong);font:inherit;border-radius:var(--radius-sm);border:1px solid var(--bd);background:var(--bg);color:var(--fg);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;gap:.45rem;padding:.6rem .95rem;font-weight:560;line-height:1;transition:background .14s,border-color .14s,transform 40ms,box-shadow .14s;display:inline-flex}.btn:hover{background:var(--surface-2)}.btn:active{transform:translateY(1px)}.btn:focus-visible{box-shadow:var(--ring);outline:none}.btn:disabled{opacity:.55;cursor:default;transform:none}.btn-primary{--bg:var(--brand-600);--fg:#fff;--bd:var(--brand-600)}.btn-primary:hover{--bg:var(--brand-700);background:var(--brand-700)}.btn-danger{--bg:var(--danger);--fg:#fff;--bd:var(--danger)}.btn-danger:hover{background:#9a1c12}.btn-ghost{--bd:transparent;--bg:transparent}.btn-ghost:hover{background:#1c19170f}.btn-block{width:100%}.btn-lg{padding:.9rem 1.2rem;font-size:1.05rem}.btn-sm{padding:.4rem .65rem;font-size:.85rem}.btn-pay{--bg:var(--brand-600);--fg:#fff;--bd:var(--brand-600);padding:1rem;font-size:1.15rem;font-weight:680}.btn-pay:hover{background:var(--brand-700)}.field{flex-direction:column;gap:.35rem;display:flex}.field>label,.label{color:var(--ink-2);font-size:.82rem;font-weight:580}input,select,textarea{width:100%;font:inherit;color:var(--ink);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:.6rem .7rem;transition:border-color .14s,box-shadow .14s}input:focus,select:focus,textarea:focus{border-color:var(--brand-600);box-shadow:var(--ring);outline:none}.field .hint{color:var(--muted);font-size:.78rem}.field .err{color:var(--danger);font-size:.78rem}.search{position:relative}.search input{padding-left:2.2rem}.search:before{content:"⌕";color:var(--muted);font-size:1.15rem;position:absolute;top:50%;left:.7rem;transform:translateY(-50%)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.panel-pad{padding:1.1rem 1.25rem}.cards{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem;margin-top:1.25rem;display:grid}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:.5rem;padding:1.1rem 1.2rem;display:flex}.card-label{color:var(--muted);font-size:.82rem;font-weight:560}.card-value{letter-spacing:-.02em;font-size:1.7rem;font-weight:680}.table-wrap{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);overflow-x:auto}table.tbl{border-collapse:collapse;width:100%;font-size:.92rem}.tbl th{text-align:left;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);background:var(--surface-2);padding:.75rem 1rem;font-size:.74rem;font-weight:620}.tbl td{border-bottom:1px solid var(--border);padding:.8rem 1rem}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr:hover{background:var(--surface-2)}.tbl .right{text-align:right}.badge{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--border);border-radius:999px;align-items:center;gap:.3rem;padding:.18rem .5rem;font-size:.74rem;font-weight:600;display:inline-flex}.badge-ok{background:var(--ok-bg);color:var(--ok);border-color:#0000}.badge-warn{background:var(--warn-bg);color:var(--warn);border-color:#0000}.badge-danger{background:var(--danger-bg);color:var(--danger);border-color:#0000}.modal-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:50;background:#1c191773;place-items:center;padding:1rem;animation:.12s fade;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;animation:.14s pop;overflow:auto}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.1rem 1.3rem;display:flex}.modal-body{padding:1.3rem}.modal-foot{border-top:1px solid var(--border);background:var(--surface);justify-content:flex-end;gap:.6rem;padding:1rem 1.3rem;display:flex;position:sticky;bottom:0}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(8px)scale(.99)}}.toaster{z-index:80;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1rem;right:1rem}.toast{background:var(--ink);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow);max-width:340px;padding:.7rem 1rem;font-size:.9rem;animation:.14s pop}.toast.ok{background:var(--brand-700)}.toast.err{background:var(--danger)}.spinner{border:2.5px solid var(--border-strong);border-top-color:var(--brand-600);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;color:var(--muted);border:1px dashed var(--border-strong);border-radius:var(--radius);background:var(--surface-2);padding:3rem 1rem}.empty .empty-title{color:var(--ink-2);margin-bottom:.25rem;font-weight:600}.tabs{border-bottom:1px solid var(--border);gap:.25rem;display:flex}.tab{font:inherit;color:var(--muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.6rem .9rem;font-weight:560}.tab.on{color:var(--ink);border-bottom-color:var(--brand-600)}.tab-count{background:var(--warn-bg);color:var(--warn);border-radius:999px;margin-left:.4rem;padding:.05rem .4rem;font-size:.72rem;font-weight:700}.layout{grid-template-columns:248px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--brand-800);color:#cdeee2;flex-direction:column;padding:1.1rem .85rem;display:flex}.sidebar.admin{color:#d6dce4;background:#20262e}.sidebar .brand{letter-spacing:-.02em;color:#fff;padding:.4rem .6rem 1.1rem;font-size:1.05rem;font-weight:720}.sidebar nav{flex-direction:column;gap:.15rem;display:flex}.sidebar nav a{border-radius:var(--radius-sm);opacity:.82;padding:.6rem .7rem;font-size:.93rem;font-weight:520}.sidebar nav a:hover{opacity:1;background:#ffffff14}.sidebar nav a.active{opacity:1;color:#fff;background:#ffffff26;font-weight:620}.main{flex-direction:column;min-width:0;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:20;align-items:center;gap:.75rem;padding:.7rem 1.5rem;display:flex;position:sticky;top:0}.topbar .user{font-size:.92rem;font-weight:600}.content{min-width:0;padding:1.75rem}.page-head{justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.25rem;display:flex}.conn{background:var(--ok-bg);color:var(--ok);border-radius:999px;align-items:center;gap:.35rem;padding:.25rem .65rem;font-size:.8rem;font-weight:560;display:inline-flex}.conn:before{content:"";background:currentColor;border-radius:50%;width:7px;height:7px}.conn.offline{background:var(--danger-bg);color:var(--danger)}.lang-toggle{min-width:46px;font-weight:700}.login{background:radial-gradient(1200px 500px at 10% -10%, var(--brand-100), transparent 55%), var(--bg);place-items:center;min-height:100vh;padding:1rem;display:grid}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%;max-width:390px;padding:2.2rem}.login-top{justify-content:flex-end;display:flex}.login-card h1{color:var(--brand-700);margin-top:.5rem;font-size:1.05rem}.login-card h2{margin:.3rem 0 1.4rem;font-size:1.5rem}.login form{flex-direction:column;gap:1rem;display:flex}.pos{grid-template-columns:1fr 380px;align-items:start;gap:1.1rem;display:grid}.pos-left{flex-direction:column;gap:.9rem;min-height:0;display:flex}.pos-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));align-content:start;gap:.7rem;max-height:calc(100vh - 215px);padding-right:.25rem;display:grid;overflow:auto}.tile{text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);cursor:pointer;min-height:96px;box-shadow:var(--shadow-sm);flex-direction:column;gap:.5rem;padding:.8rem;transition:border-color .12s,transform 50ms;display:flex}.tile:hover{border-color:var(--brand-600)}.tile:active{transform:translateY(1px)}.tile:disabled{opacity:.5;cursor:default}.tile .t-name{font-size:.92rem;font-weight:600;line-height:1.25}.tile .t-meta{justify-content:space-between;align-items:baseline;margin-top:auto;display:flex}.tile .t-price{font-weight:680}.tile .t-stock{color:var(--muted);font-size:.75rem}.cart{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;min-height:0;max-height:calc(100vh - 110px);display:flex;position:sticky;top:1rem}.cart-head{border-bottom:1px solid var(--border);padding:.9rem 1.1rem;font-weight:650}.cart-items{flex:1;padding:.5rem;overflow:auto}.cart-item{border-radius:var(--radius-sm);grid-template-columns:1fr auto;gap:.2rem .6rem;padding:.6rem;display:grid}.cart-item:hover{background:var(--surface-2)}.cart-item .ci-name{font-weight:580}.cart-item .ci-line{text-align:right;font-weight:650}.qty{border:1px solid var(--border-strong);border-radius:999px;align-items:center;display:inline-flex;overflow:hidden}.qty button{background:var(--surface-2);cursor:pointer;border:none;width:30px;height:30px;font-size:1.1rem;line-height:1}.qty button:hover{background:var(--border)}.qty span{text-align:center;min-width:34px;font-weight:620}.cart-foot{border-top:1px solid var(--border);flex-direction:column;gap:.8rem;padding:1rem 1.1rem;display:flex}.total-row{justify-content:space-between;align-items:baseline;display:flex}.total-row .t-amount{letter-spacing:-.02em;font-size:1.7rem;font-weight:720}.pay-methods{grid-template-columns:repeat(3,1fr);gap:.4rem;display:grid}.pay-methods .seg{text-align:center;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;padding:.55rem;font-size:.9rem;font-weight:560}.pay-methods .seg.on{border-color:var(--brand-600);background:var(--brand-50);color:var(--brand-700)}.receipt{font-variant-numeric:tabular-nums}.receipt .r-line{justify-content:space-between;padding:.2rem 0;display:flex}.receipt .r-total{border-top:1px dashed var(--border-strong);margin-top:.5rem;padding-top:.5rem;font-size:1.1rem;font-weight:700}@media (width<=900px){.layout{grid-template-columns:1fr}.pos{grid-template-columns:1fr;height:auto}}
