*{box-sizing:border-box}:root{--bg:#eceff1;--surface:#ffffff;--surface-soft:#f8fafc;--line:#c7cdd3;--line-strong:#8f99a3;--text:#1f2a33;--muted:#5d6873;--accent:#ffb300;--accent-strong:#ff8f00;--new:#dcedff;--prep:#fff2d4;--ready:#dffbe4}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:linear-gradient(140deg,rgba(255,255,255,.5),transparent 48%),repeating-linear-gradient(135deg,#e8ecef,#e8ecef 18px,#edf1f4 0,#edf1f4 36px);color:var(--text)}main{max-width:none;width:100%;margin:0 auto;padding:1rem 1.2rem}.auth-main{min-height:100vh;display:grid;place-items:center;padding:1rem}.auth-card{width:min(560px,100%);border:1px solid #c4d0db;border-radius:18px;padding:1.1rem;background:#fff;box-shadow:0 14px 30px rgba(20,33,49,.14)}.auth-title{margin:0;font-size:1.7rem}.auth-subtitle{margin:.35rem 0 1rem;color:var(--muted)}.auth-field{display:grid;grid-gap:.35rem;gap:.35rem;margin-top:.9rem}.auth-field-label{margin:0;font-size:.9rem;font-weight:700;color:#3c4956}.auth-pin-input{font-size:1.2rem;letter-spacing:.24rem;text-align:center;font-weight:700}.auth-role-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:.55rem;gap:.55rem}.auth-role-btn{display:grid;text-align:left;min-height:76px;border:1px solid #c8d4de;background:#f8fbfe}.auth-role-btn span{color:#5b6773;font-size:.8rem;line-height:1.2}.auth-role-btn.active{border-color:#1c93ad;background:#e8f9fd}.auth-demo-row{margin-top:.9rem;display:flex;gap:.45rem;align-items:center;flex-wrap:wrap;color:#4e5a66;font-size:.85rem}.auth-demo-btn{border-radius:999px;padding:.34rem .62rem;background:#f3f7fa;border:1px solid #c7d3dd;font-size:.8rem}.auth-submit{width:100%;margin-top:1rem}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-error{margin:.8rem 0 0;padding:.55rem .7rem;border-radius:10px;border:1px solid #f2b2b2;background:#fff0f0;color:#8f1e1e;font-weight:600}.auth-hint{margin:.75rem 0 0;color:var(--muted);font-size:.9rem}button{cursor:pointer;border-radius:10px;border:1px solid var(--line-strong);background:var(--surface);color:var(--text);font-weight:600;padding:.62rem .9rem}button:hover{border-color:#5d6771}input,select,textarea{border:1px solid var(--line);border-radius:10px;padding:.58rem .7rem;font-size:.94rem;color:var(--text);background:var(--surface)}.card{border:1px solid var(--line);border-radius:14px;padding:1rem;margin-bottom:1rem;background:var(--surface);box-shadow:0 3px 9px rgba(15,23,42,.06)}.row{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap}.pill{padding:.27rem .65rem;border-radius:999px;border:1px solid var(--line-strong);background:#f1f4f6;color:var(--muted);font-size:.82rem}.page-title{margin:0 0 .85rem;font-size:1.8rem;letter-spacing:.4px}.industrial-panel{border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,#ffffff,#f4f6f8);box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}.split-layout{display:grid;grid-template-columns:1.65fr 1fr;grid-gap:1rem;gap:1rem;align-items:start}@media (max-width:1040px){.split-layout{grid-template-columns:1fr}}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(30%,1fr));grid-gap:.9rem;gap:.9rem}.product-card{border:1px solid var(--line);border-radius:14px;padding:.65rem;background:var(--surface);box-shadow:0 2px 8px rgba(2,6,23,.06)}.product-image{width:100%;height:145px;object-fit:cover;border-radius:10px;border:1px solid #ccd2d8;background:#e5eaef}.chip-row{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.45rem}.chip-btn{border:1px solid #adb6bf;border-radius:999px;background:#f6f8fa;padding:.3rem .62rem;font-size:.82rem;font-weight:600;color:#3a4650}.chip-btn.active{border-color:#a86e00;background:linear-gradient(180deg,#ffe7a6,#ffd66a);color:#5b3b00}.primary-btn{border-color:#9d6900;background:linear-gradient(180deg,var(--accent) 0,var(--accent-strong) 100%);color:#2a1b00}.order-panel{position:-webkit-sticky;position:sticky;top:.8rem}.order-line{border:1px solid var(--line);border-radius:10px;padding:.55rem .65rem;background:#f8fafb;margin-bottom:.55rem}.kitchen-toolbar{display:flex;gap:.8rem;align-items:center;margin-bottom:1rem;padding:.75rem}.kitchen-board{display:grid;grid-template-columns:repeat(3,minmax(280px,1fr));grid-gap:.9rem;gap:.9rem}@media (max-width:1120px){.kitchen-board{grid-template-columns:1fr}}.stage-column{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff}.stage-head{border-bottom:1px solid var(--line);padding:.62rem .82rem;font-weight:700;display:flex;align-items:center;justify-content:space-between}.stage-head.new{background:var(--new)}.stage-head.prep{background:var(--prep)}.stage-head.ready{background:var(--ready)}.stage-body{min-height:110px;padding:.7rem}.order-card{border:1px solid var(--line);border-left:6px solid #9bb4c9;border-radius:12px;background:#fff;padding:.72rem;margin-bottom:.7rem}.order-card.prep{border-left-color:#d8a14c}.order-card.ready{border-left-color:#57ad67}.swipe-action{width:100%;margin-top:.5rem;border:1px solid #a1abb4;background:linear-gradient(90deg,#f1f3f5,#dce3ea);display:flex;align-items:center;justify-content:center;gap:.35rem}.muted{color:var(--muted);font-size:.88rem}.section-title{margin:0 0 .6rem;font-size:1.06rem}.qty-btn{width:32px;height:32px;padding:0}.ghost-btn{background:#f3f5f7}.app-shell{min-height:100vh;padding:1rem}.pos-frame{display:grid;grid-template-columns:220px 1fr 320px;grid-gap:1rem;gap:1rem;border:1px solid #b9c4cf;width:100%;min-height:calc(100vh - 2rem);border-radius:20px;padding:.9rem;background:#f9fcff;box-shadow:0 12px 28px rgba(28,39,54,.15)}.pos-frame.no-right{grid-template-columns:220px 1fr}.sidebar-panel{border:1px solid #bfd0de;border-radius:16px;background:#fff;padding:1rem .75rem}.brand{font-weight:800;color:#17647a;margin:0 0 1rem;letter-spacing:.5px}.side-nav{display:grid;grid-gap:.35rem;gap:.35rem}.side-link{border:1px solid transparent;border-radius:10px;background:transparent;text-align:left;font-weight:600;color:#506070;padding:.55rem .65rem}.side-link.active{border-color:#1a798f;background:#0d6d84;color:#fff}.main-panel{border:1px solid #c2d0dc;border-radius:16px;background:#fff;padding:.9rem;min-height:0}.top-bar{display:flex;align-items:center;gap:.6rem;margin-bottom:.8rem}.search-input{flex:1 1;min-width:240px;background:#f7fafc}.icon-btn{width:40px;height:40px;border-radius:10px;padding:0}.category-tabs{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:.9rem}.category-tab{border:1px solid #c0cbd7;border-radius:10px;background:#f7fafd;color:#4f6070;padding:.4rem .7rem;font-size:.86rem}.category-tab.active{border-color:#1590aa;background:#e6f7fb;color:#0b758c}.bill-panel{border:1px solid #bfd0de;border-radius:16px;background:#fff;padding:.85rem}.sank-main-panel{display:flex;flex-direction:column;min-height:0}.sank-products-scroll{overflow-y:auto;padding-right:.2rem}.sank-bill-panel{position:-webkit-sticky;position:sticky;top:.9rem;display:flex;flex-direction:column;max-height:calc(100vh - 3rem)}.sank-bill-lines{overflow-y:auto;padding-right:.15rem;min-height:110px}.sank-ready-list{max-height:120px;overflow-y:auto;padding-right:.2rem}.bill-line{border-bottom:1px dashed #cad5df;padding:.4rem 0}.summary-line{margin:.25rem 0;color:#5d6873}.summary-line,.summary-total{display:flex;justify-content:space-between}.summary-total{font-size:1.05rem;font-weight:800;margin-top:.65rem}.kitchen-frame{display:grid;grid-template-columns:220px 1fr;grid-gap:1rem;gap:1rem;border:1px solid #b9c4cf;min-height:calc(100vh - 2rem);border-radius:20px;padding:.9rem;background:#f9fcff;box-shadow:0 12px 28px rgba(28,39,54,.15)}.kitchen-columns{display:grid;grid-template-columns:repeat(3,minmax(240px,1fr));grid-gap:.8rem;gap:.8rem;min-height:0}.kitchen-main-panel{display:flex;flex-direction:column;min-height:0}.kitchen-columns-scroll{overflow-y:auto;padding-right:.2rem}.k-column{border:1px solid #c2d0dc;border-radius:14px;overflow:hidden;background:#fff}.k-head{padding:.6rem .7rem;font-weight:700;border-bottom:1px solid #d2dde7}.k-head.new{background:#dff3ff}.k-head.prep{background:#fff0cd}.k-head.ready{background:#dff6df}.k-body{padding:.65rem;min-height:150px;max-height:62vh;overflow-y:auto}.admin-layout{display:grid;grid-template-columns:220px 1fr;grid-gap:1rem;gap:1rem;border:1px solid #b9c4cf;border-radius:20px;padding:.9rem;background:#f9fcff;box-shadow:0 12px 28px rgba(28,39,54,.15)}.admin-grid{display:grid;grid-template-columns:260px 1fr;grid-gap:.9rem;gap:.9rem}.category-list{border:1px solid #ced7df;border-radius:12px;padding:.6rem;background:#f9fcff}.category-item{width:100%;text-align:left;margin-bottom:.35rem;border:1px solid #d5dde6;background:#fff}.category-item.active{border-color:#1c93ad;background:#e7f8fb}.admin-product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:.7rem;gap:.7rem}.admin-product-card{border:1px solid #d4dde6;border-radius:12px;padding:.5rem;background:#fff}.admin-thumb{width:72px;height:72px;border-radius:50%;object-fit:cover;border:1px solid #d0d8df;display:block;margin:0 auto .45rem}@media (max-width:1260px){.pos-frame{grid-template-columns:90px 1fr;min-height:auto}.pos-frame .bill-panel{grid-column:1/-1}.sank-bill-panel{position:static;max-height:none}.sank-bill-lines{max-height:38vh}}@media (max-width:1100px){.admin-grid,.admin-layout,.kitchen-columns,.kitchen-frame{grid-template-columns:1fr}}@media (max-width:660px){.auth-role-grid{grid-template-columns:1fr}}