@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap";:root{--bg: #f8f6ec;--bg2: #f0f5dd;--surface: rgba(255,250,240,.84);--border: rgba(189,208,160,.68);--border-s: #d8e3bf;--ink: #20311f;--ink-2: #425043;--ink-3: #6f7e70;--green: #4f8f54;--green-mid: #3f7f45;--green-light: #e4f1d4;--green-glow: rgba(79,143,84,.18);--terra: #d06856;--terra-light: #fbebe5;--amber: #be8735;--amber-light: #fff5d8;--red: #c85c54;--red-light: #fde8e4;--blue: #5d8f66;--blue-light: #edf7e4;--radius: 16px;--radius-s: 10px;--radius-l: 24px;--shadow-s: 0 4px 16px rgba(79,143,84,.08), 0 1px 4px rgba(79,143,84,.04);--shadow-m: 0 10px 30px rgba(79,143,84,.12);--shadow-l: 0 20px 50px rgba(79,143,84,.15);--shadow-xl: 0 30px 70px rgba(79,143,84,.18);--font-display: "Bricolage Grotesque", ui-sans-serif, system-ui, sans-serif;--font-body: "DM Sans", ui-sans-serif, system-ui, sans-serif;--sidebar-w: 224px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent}body{background:radial-gradient(circle at top left,rgba(245,221,156,.26),transparent 28%),radial-gradient(circle at top right,rgba(134,176,120,.18),transparent 24%),linear-gradient(135deg,#f7f4e7,#fefcf5 45%,#e3efcf);background-attachment:fixed;color:var(--ink);font-family:var(--font-body);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}button,input,textarea,select{font:inherit;color:inherit}button{border:0;cursor:pointer;background:transparent}button:disabled{cursor:not-allowed;opacity:.5}a{text-decoration:none}img{display:block}h1,h2,h3,h4{font-family:var(--font-display);line-height:1.2}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-s);border-radius:99px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 16px;border-radius:999px;font-weight:500;font-size:14px;white-space:nowrap;transition:background .15s,box-shadow .15s,transform .1s;min-height:38px}.btn:active:not(:disabled){transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,#66a86a,#4f8f54);color:#fff;box-shadow:0 2px 10px var(--green-glow)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#568f5a,#3f7f45)}.btn-ghost{background:var(--bg2);color:var(--ink);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:#e0ecff}.btn-danger{background:var(--red-light);color:var(--red)}.btn-danger:hover:not(:disabled){background:#f9d4d1}.btn-full{width:100%}.btn-lg{min-height:48px;padding:12px 20px;font-size:15px}.field{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--radius-s);background:#ffffffd9;color:var(--ink);transition:border-color .15s,box-shadow .15s}.field:focus{outline:none;border-color:var(--green-mid);box-shadow:0 0 0 3px var(--green-glow)}.field::placeholder{color:var(--ink-3)}textarea.field{min-height:80px;resize:vertical}select.field{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M0 0l6 8 6-8z' fill='%2364748b'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap}.badge-new{background:var(--amber-light);color:var(--amber)}.badge-preparing{background:#fff3cd;color:#7a4800}.badge-delivering{background:var(--blue-light);color:var(--blue)}.badge-delivered{background:var(--green-light);color:var(--green)}.badge-cancelled{background:#f0ece6;color:var(--ink-3)}.badge-paid{background:var(--green-light);color:var(--green)}.badge-unpaid,.badge-pending_payment{background:var(--amber-light);color:var(--amber)}.badge-owner{background:#ede9fc;color:#5b21b6}.badge-admin{background:var(--blue-light);color:var(--blue)}.badge-staff{background:var(--bg2);color:var(--ink-2)}.notice{padding:12px 14px;border-radius:var(--radius-s);background:var(--green-light);color:var(--green);font-size:14px}.notice-warn{background:var(--amber-light);color:var(--amber)}.notice-err{background:var(--red-light);color:var(--red)}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-head h2{font-size:1.1rem;font-family:var(--font-display)}.section-head .count{font-size:13px;font-weight:600;color:var(--ink-3)}.app-shell{min-height:100svh;display:grid;grid-template-columns:var(--sidebar-w) minmax(0,1fr)}.sidebar{position:sticky;top:0;width:var(--sidebar-w);display:flex;flex-direction:column;background:linear-gradient(180deg,#5a8e58,#6f9f62 55%,#86b05f);color:#fff;z-index:10;overflow-y:auto;height:100svh}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:20px 16px 16px;font-family:var(--font-display);font-size:1.05rem;font-weight:800;border-bottom:1px solid rgba(255,255,255,.1);color:#fff}.sidebar-brand svg{color:#f6e6a8}.sidebar-nav{flex:1;padding:10px 6px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:12px;font-size:13px;font-weight:600;color:#ffffffb3;transition:background .15s,color .15s;cursor:pointer}.nav-item:hover{background:#ffffff1f;color:#fff}.nav-item.active{background:#fff3;color:#fff;box-shadow:0 0 0 1px #ffffff26}.nav-item svg{flex-shrink:0}.nav-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-footer{padding:10px 6px 16px;border-top:1px solid rgba(255,255,255,.1)}.workspace{grid-column:2;min-width:0;min-height:100svh;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background:#f8f6eceb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}.topbar-actions{display:flex;align-items:center;gap:8px}.topbar-menu-btn{display:none}.topbar-user p{font-size:12px;color:var(--ink-3);margin-bottom:1px}.topbar-user h1{font-size:1.15rem}.workspace-body{padding:24px;flex:1;min-width:0}.ov-root{display:flex;flex-direction:column;gap:20px}.ov-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:80px 24px;color:var(--ink-3);font-size:14px}.ov-spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ov-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.ov-title{font-family:var(--font-display);font-size:1.35rem;font-weight:800;color:var(--ink)}.ov-subtitle{font-size:13px;color:var(--ink-3);margin-top:2px}.ov-period-tabs{display:flex;gap:6px;flex-wrap:wrap}.ov-period-btn{padding:7px 14px;border-radius:999px;font-size:13px;font-weight:600;background:#ffffffb3;border:1.5px solid var(--border);color:var(--ink-3);transition:all .15s;cursor:pointer}.ov-period-btn:hover{border-color:var(--green);color:var(--green)}.ov-period-btn.active{background:linear-gradient(135deg,#66a86a,#4f8f54);border-color:transparent;color:#fff;box-shadow:0 3px 10px var(--green-glow)}.ov-row1{display:grid;grid-template-columns:280px 1fr;gap:18px;align-items:stretch}.ov-metrics-col{display:flex;flex-direction:column;gap:14px}.ov-metric-card{display:flex;align-items:center;gap:14px;padding:20px 18px;background:#ffffffd1;border:1px solid rgba(255,255,255,.6);border-radius:var(--radius);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow-s);transition:transform .2s,box-shadow .2s}.ov-metric-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-m)}.ov-metric-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ov-metric-revenue .ov-metric-icon{background:#dbeafe;color:#2563eb}.ov-metric-orders .ov-metric-icon{background:#f7e9d0;color:#b86d22}.ov-metric-body{min-width:0}.ov-metric-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-3);margin-bottom:6px}.ov-metric-value{font-family:var(--font-display);font-size:1.6rem;font-weight:800;color:var(--ink);line-height:1}.ov-metric-unit{font-size:1rem;font-weight:500;color:var(--ink-3)}.ov-chart-card{background:#ffffffd1;border:1px solid rgba(255,255,255,.6);border-radius:var(--radius);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow-s);padding:20px 20px 12px;display:flex;flex-direction:column}.ov-chart-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:2px}.ov-chart-subtitle{font-size:12px;color:var(--ink-3);margin-bottom:16px}.ov-bar-xaxis-label{text-align:center;font-size:11px;color:var(--ink-3);margin-top:4px;font-style:italic}.ov-empty-chart{flex:1;display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:14px}.ov-row2{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}.ov-ranking-header{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-size:.95rem;font-weight:700;color:var(--ink);padding:16px 18px 12px;border-bottom:1px solid var(--border)}.ov-ranking-header svg{color:var(--green);flex-shrink:0}.ov-ranking-card{background:#ffffffd1;border:1px solid rgba(255,255,255,.6);border-radius:var(--radius);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow-s);overflow:hidden}.ov-ranking-list{display:flex;flex-direction:column}.ov-ranking-row{display:flex;align-items:center;gap:12px;padding:12px 18px;border-bottom:1px solid var(--border);transition:background .15s;cursor:default}.ov-ranking-row:last-child{border-bottom:none}.ov-ranking-row:hover{background:#2563eb0a}.ov-ranking-row.top3{background:#2563eb08}.ov-ranking-row.top3:hover{background:#2563eb12}.ov-rank-badge{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;flex-shrink:0}.ov-rank-info{flex:1;min-width:0}.ov-rank-name{font-weight:600;font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ov-rank-qty{font-size:12px;color:var(--ink-3);margin-top:1px}.ov-rank-revenue{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--green);white-space:nowrap}.ov-pie-card{background:#ffffffd1;border:1px solid rgba(255,255,255,.6);border-radius:var(--radius);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow-s);overflow:hidden}.ov-pie-layout{display:flex;flex-direction:column;align-items:center;padding:8px 18px 18px;gap:12px}.ov-pie-legend{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:6px 16px}.ov-legend-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:background .15s}.ov-legend-item:hover,.ov-legend-item.active{background:#2563eb12}.ov-legend-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}.ov-legend-label{display:flex;flex-direction:column;min-width:0}.ov-legend-name{font-size:12px;font-weight:600;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ov-legend-pct{font-size:11px;color:var(--ink-3)}.orders-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.order-card{padding:16px;display:flex;flex-direction:column;gap:12px;border-radius:var(--radius);background:#ffffffd1;border:1px solid rgba(255,255,255,.6);box-shadow:var(--shadow-s);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transition:transform .2s,box-shadow .2s}.order-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-m)}.order-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.order-card-header h3{font-size:1rem;font-family:var(--font-display)}.order-card-header .price{font-weight:700;font-size:1rem;color:var(--green);white-space:nowrap}.order-badges{display:flex;flex-wrap:wrap;gap:5px}.order-items-list{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:var(--bg2);border-radius:var(--radius-s)}.order-item-row{font-size:13px;color:var(--ink-2);display:flex;justify-content:space-between;gap:8px}.order-actions{display:flex;flex-wrap:wrap;gap:6px}.orders-toolbar{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.orders-search-box{width:min(520px,100%)}.orders-filter-toggle-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.menu-add-form{display:grid;grid-template-columns:160px 1fr;gap:16px;padding:16px;background:#ffffffd1;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;box-shadow:var(--shadow-s)}.menu-add-form .form-fields{display:flex;flex-direction:column;gap:10px}.image-picker{position:relative;width:160px;height:160px;border:2px dashed var(--border-s);border-radius:var(--radius);background:var(--bg2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;color:var(--ink-3);font-size:13px;font-weight:500;overflow:hidden;transition:border-color .2s,background .2s}.image-picker:hover{border-color:var(--green-mid);background:var(--green-light);color:var(--green)}.image-picker input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.image-picker img{width:100%;height:100%;object-fit:cover}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.menu-admin-card{border-radius:var(--radius);border:1px solid var(--border);background:#ffffffd1;overflow:hidden;box-shadow:var(--shadow-s);transition:transform .2s;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.menu-admin-card:hover{transform:translateY(-4px)}.menu-admin-card img{width:100%;height:120px;object-fit:cover}.menu-admin-card .info{display:flex;justify-content:space-between;align-items:center;gap:8px}.menu-admin-card b{font-size:14px}.menu-admin-card .price{font-weight:700;color:var(--green);font-size:13px;white-space:nowrap}.menu-admin-body{padding:12px;display:flex;flex-direction:column;gap:10px}.menu-admin-desc{font-size:13px;line-height:1.45}.card-edit-panel{display:flex;flex-direction:column;gap:8px;padding:12px}.admin-card-actions{display:flex;flex-wrap:wrap;gap:8px}.menu-admin-card.is-muted,.qr-card.is-muted{opacity:.7;filter:grayscale(.2)}.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}.qr-card{display:grid;grid-template-columns:110px 1fr;gap:14px;padding:14px;border-radius:var(--radius);border:1px solid var(--border);background:#ffffffd1;box-shadow:var(--shadow-s);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.qr-card img{width:110px;height:110px;border-radius:var(--radius-s);border:1px solid var(--border)}.qr-card-body h3{font-size:1rem;margin-bottom:2px}.qr-card-body .code{font-size:12px;color:var(--ink-3);font-weight:600;margin-bottom:4px}.qr-card-body .url{font-size:12px;color:var(--green);overflow-wrap:anywhere;margin-bottom:10px;display:block}.qr-card-body .actions{display:flex;gap:6px;flex-wrap:wrap}.account-create{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;padding:16px;background:#ffffffd1;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:20px;box-shadow:var(--shadow-s)}.account-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}.user-card{padding:16px;border-radius:var(--radius);border:1px solid var(--border);background:#ffffffd1;box-shadow:var(--shadow-s);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.user-card-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.user-card-head b{font-size:15px}.user-card-head p{font-size:13px;color:var(--ink-3);margin-top:2px;word-break:break-word}.user-card-form{display:flex;flex-direction:column;gap:8px}.inline-form{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start;margin-bottom:16px}.inline-form .field{max-width:200px;flex:1 1 120px}.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 0}.page-btn{min-width:34px;height:34px;border-radius:var(--radius-s);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;background:#ffffffd1;border:1px solid var(--border);color:var(--ink-2);transition:background .15s,border-color .15s}.page-btn:hover:not(:disabled){border-color:var(--green);color:var(--green)}.page-btn.active{background:linear-gradient(135deg,#7cb26d,#5f9a5f);border-color:transparent;color:#fff}.page-btn:disabled{opacity:.4}.login-page{min-height:100svh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top left,rgba(238,206,143,.22),transparent 24%),radial-gradient(circle at top right,rgba(123,173,117,.14),transparent 24%),linear-gradient(150deg,#f8f4e8,#eef5d8 60%,#e6f1cf 140%)}.login-card{width:min(400px,100%);padding:36px 32px;background:#fffffff5;border-radius:var(--radius-l);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:14px}.login-card .logo-area{display:flex;align-items:center;gap:12px;margin-bottom:8px}.login-card .logo-area svg{color:var(--green)}.login-card .logo-area h1{font-family:var(--font-display);font-size:1.5rem}.login-card .sub{font-size:13px;color:var(--ink-3);margin-top:-8px}.field-group{display:flex;align-items:center;gap:12px;padding:0 12px;border:1.5px solid var(--border);border-radius:var(--radius-s);background:#ffffffd9}.field-group svg{flex-shrink:0;color:var(--ink-3)}.field-group .field{flex:1;border:none;background:transparent;padding:12px 0;font-size:16px}.customer-login{min-height:100svh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at top left,rgba(238,206,143,.28),transparent 28%),radial-gradient(circle at bottom right,rgba(123,173,117,.18),transparent 30%),linear-gradient(160deg,#f8f4e8,#eef5d8)}.login-phone-card{width:min(380px,100%);padding:32px 28px;background:#fffffff7;border-radius:var(--radius-l);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:16px}.login-phone-card .brand-area{display:flex;align-items:center;gap:12px}.login-phone-card .brand-area svg{color:var(--green)}.login-phone-card h1{font-family:var(--font-display);font-size:1.6rem}.login-phone-card .desc{font-size:14px;color:var(--ink-3);margin-top:-8px}.login-phone-card .input-row{display:flex;flex-direction:column;gap:10px}.customer-shell{min-height:100svh;width:min(100%,640px);margin:0 auto;display:flex;flex-direction:column;background:radial-gradient(circle at top left,rgba(238,206,143,.34),transparent 30%),radial-gradient(circle at top right,rgba(123,173,117,.18),transparent 28%),linear-gradient(180deg,#f8f4e8,#eef5d8);position:relative;overflow:hidden}.customer-shell:before,.customer-shell:after{content:"";position:fixed;inset:auto;pointer-events:none;border-radius:50%;filter:blur(2px);opacity:.45}.customer-shell:before{width:110px;height:110px;right:-24px;top:90px;background:radial-gradient(circle,#eece8fa6,#eece8f00 68%)}.customer-shell:after{width:140px;height:140px;left:-36px;bottom:140px;background:radial-gradient(circle,#7bad7552,#7bad7500 70%)}.customer-topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:12px;padding:14px 18px;background:linear-gradient(135deg,#6fa25a,#8db85f);color:#fff;box-shadow:0 10px 30px #4f8f5433}.customer-topbar .table-name{font-family:var(--font-display);font-size:1.1rem;font-weight:700;flex:1}.customer-topbar .phone-chip{background:#ffffff3d;padding:4px 10px;border-radius:99px;font-size:12px;font-weight:600;box-shadow:inset 0 0 0 1px #ffffff2e}.tab-bar{display:flex;background:#ffffffe0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(37,99,235,.08);position:sticky;top:54px;z-index:9}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:13px 8px;font-size:14px;font-weight:600;color:var(--ink-3);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.tab-btn.active{color:var(--green-mid);border-bottom-color:var(--green-mid)}.tab-btn .tab-badge{background:var(--terra);color:#fff;border-radius:99px;min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;padding:0 5px}.customer-menu-tab{flex:1;overflow-y:auto;padding:20px 22px 24px;display:flex;flex-direction:column;gap:24px}.menu-filter-panel{display:flex;flex-direction:column;gap:12px;margin-bottom:4px}.menu-search-box{display:flex;align-items:center;gap:10px;padding:0 12px;background:#ffffffdb;border:1px solid var(--border);border-radius:999px}.menu-search-box .field{border:none;background:transparent;padding:12px 0}.menu-filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{padding:8px 13px;border-radius:999px;border:1px solid var(--border);background:#ffffffe0;color:var(--ink-2);font-size:13px;font-weight:600;transition:transform .12s,background .12s,border-color .12s,color .12s}.filter-chip:hover{transform:translateY(-1px);border-color:var(--green-mid);color:var(--green-mid)}.filter-chip.active{background:linear-gradient(135deg,#7cb26d,#5f9a5f);color:#fff;border-color:transparent;box-shadow:0 6px 16px #4f8f542e}.cute-empty{border:1px dashed var(--border);background:#ffffffbf;border-radius:22px}.cute-empty p{font-family:var(--font-display);font-size:15px;color:var(--ink-2)}.category-section h2{font-size:13px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.menu-item-row{display:grid;grid-template-columns:84px minmax(0,1fr) auto;align-items:center;gap:14px;padding:14px;background:#ffffffe0;border-radius:var(--radius);border:1px solid rgba(143,171,118,.15);box-shadow:0 4px 16px #4f8f5412;transition:box-shadow .15s,transform .15s}.menu-item-row:active{box-shadow:none;transform:translateY(1px)}.menu-item-row img{width:84px;height:84px;border-radius:24px;object-fit:cover;box-shadow:0 6px 18px #4f8f5414}.menu-item-row .item-name{font-weight:600;font-size:14px;line-height:1.3}.menu-item-row .item-name:after{content:" ✦";color:var(--terra);font-size:11px}.menu-item-row .item-desc{font-size:12px;color:var(--ink-3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-item-row .item-price{font-weight:700;font-size:14px;color:var(--green);margin-top:4px}.menu-item-row.sold-out{opacity:.58}.sold-out-label{min-width:74px;text-align:center;font-size:13px;font-weight:800;color:var(--red);background:var(--red-light);border:1px solid rgba(200,92,84,.35);padding:7px 10px;border-radius:999px}.stepper{display:flex;align-items:center;gap:6px;flex-shrink:0}.stepper-btn{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--ink);transition:background .15s,transform .1s;flex-shrink:0}.stepper-btn:active{transform:scale(.9)}.stepper-btn.add{background:linear-gradient(135deg,#7cb26d,#5f9a5f);color:#fff}.stepper-count{width:22px;text-align:center;font-weight:700;font-size:15px}.cart-footer{position:sticky;bottom:0;z-index:8;margin:0 12px 12px;padding:12px 14px 14px;background:#fffffff5;border:1px solid rgba(143,171,118,.16);border-radius:22px;box-shadow:0 -4px 20px #4f8f541a}.cart-footer-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.cart-summary-text{font-size:13px;color:var(--ink-3)}.cart-summary-text b{color:var(--ink)}.cart-total-row{font-size:15px;font-weight:700}.cart-total-row .total-amt{color:var(--green);font-family:var(--font-display);font-size:1.1rem}.cart-tab{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.cart-empty{text-align:center;padding:48px 24px;color:var(--ink-3)}.cart-empty svg{margin:0 auto 12px;opacity:.4}.cart-lines{display:flex;flex-direction:column;background:#ffffffe6;border-radius:22px;border:1px solid var(--border);overflow:hidden}.cart-line{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}.cart-line:last-child{border-bottom:none}.cart-line .name{flex:1;font-size:14px;font-weight:500}.cart-line .subtotal{font-weight:700;font-size:14px;color:var(--green);white-space:nowrap}.cart-note label{display:block;font-size:13px;font-weight:600;color:var(--ink-3);margin-bottom:6px}.cart-summary-card{padding:14px;background:#ffffffe0;border:1px solid var(--border);border-radius:var(--radius)}.cart-summary-card .row{display:flex;justify-content:space-between;gap:8px;font-size:14px;padding:3px 0}.cart-summary-card .total-row{font-size:16px;font-weight:800;padding-top:10px;margin-top:8px;border-top:1px solid var(--border)}.cart-summary-card .total-row .total-amt{color:var(--green);font-family:var(--font-display)}.history-tab{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.history-card{padding:14px;background:#ffffffe6;border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow-s)}.history-card-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}.history-card-head .order-meta b{font-family:var(--font-display);font-size:1rem}.history-card-head .order-meta .time{font-size:12px;color:var(--ink-3);margin-top:2px}.history-card-head .price-col .amt{font-weight:700;color:var(--green);font-size:15px}.history-badges{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}.history-items{font-size:13px;color:var(--ink-2);display:flex;flex-wrap:wrap;gap:4px}.history-items span{background:var(--bg2);padding:2px 8px;border-radius:99px}.menu-category-panel{padding:16px;background:#ffffffd6;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-s);margin-bottom:16px}.menu-category-toggle{width:100%;min-height:44px;margin-bottom:12px;padding:10px 14px;border:1px solid var(--border);border-radius:14px;background:#ffffffd6;box-shadow:var(--shadow-s);display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--ink-2);font-weight:600;transition:border-color .15s,box-shadow .15s,transform .12s}.menu-category-toggle:hover{border-color:var(--green-mid);box-shadow:0 8px 20px #4f8f541f}.menu-category-toggle:active{transform:translateY(1px)}.menu-category-toggle.active{border-color:#4f8f5473;background:#e4f1d4b8}.menu-category-toggle-left{display:inline-flex;align-items:center;gap:8px}.menu-category-toggle-count{font-size:12px;font-weight:700;color:var(--ink-3);background:#f0f5dde6;border:1px solid var(--border);border-radius:999px;padding:3px 9px}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.category-admin-card{padding:14px;background:#ffffffe6;border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-s)}.category-admin-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.category-admin-head b{font-size:15px}.category-order{background:var(--bg2);color:var(--ink-2);padding:4px 8px;border-radius:999px;font-size:11px;font-weight:700}.category-admin-edit{display:flex;flex-direction:column;gap:8px}.menu-category-form{margin-bottom:14px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:20px;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}}.modal{width:min(460px,calc(100vw - 32px));padding:28px 24px;background:#fffffffa;border-radius:28px;border:1px solid rgba(37,99,235,.1);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:14px;animation:slideUp .2s ease;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}}.modal-close-btn{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:999px;border:1px solid var(--border);background:#ffffffeb;color:var(--ink-3);display:inline-flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.modal-close-btn:hover{border-color:var(--red);color:var(--red);background:var(--red-light)}.modal-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center}.modal-icon.success{background:var(--green-light);color:var(--green)}.modal-icon.info{background:var(--blue-light);color:var(--blue)}.modal-icon.warning{background:var(--amber-light);color:var(--amber)}.modal h2{font-size:1.25rem}.modal p{font-size:14px;color:var(--ink-2);line-height:1.6}.modal-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}.modal-actions .btn{min-height:46px}.payment-qr-box{display:flex;flex-direction:column;align-items:center;gap:10px;padding:16px;background:linear-gradient(180deg,#f8f2e4,#fff);border-radius:18px;border:1px solid rgba(37,99,235,.08)}.payment-qr-box img{width:192px;height:192px;border-radius:14px;box-shadow:0 8px 24px #2563eb1a}.payment-qr-box p{font-size:13px;color:var(--ink-3);text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ab3;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:fadeIn .2s ease-out}.modal-content{background:#fffffffa;border-radius:var(--radius);box-shadow:var(--shadow-xl);max-width:500px;width:100%;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h2{margin:0;font-size:18px;font-weight:700}.modal-header .btn{padding:6px 10px;font-size:18px}.modal-body{padding:16px;flex:1;overflow-y:auto}.bill-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.bill-section:last-child{border-bottom:none}.bill-section h3{margin:0 0 12px;font-size:14px;font-weight:700;color:var(--ink-2);text-transform:uppercase;letter-spacing:.5px}.bill-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:6px 0;font-size:13px}.bill-row span{color:var(--ink-2)}.timeline{display:flex;flex-direction:column;gap:16px}.timeline-item{display:flex;gap:12px}.timeline-marker{flex-shrink:0;width:12px;height:12px;margin-top:4px;border-radius:50%;background:var(--green)}.timeline-label{font-weight:700;color:var(--ink);font-size:13px}.timeline-time{font-size:12px;color:var(--ink-2);margin-top:2px}.timeline-details{font-size:12px;color:var(--ink-3);margin-top:4px}.result-page{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px;text-align:center;background:linear-gradient(160deg,#6ea35a,#3f7f45);color:#fff}.result-page h1{font-family:var(--font-display);font-size:1.5rem}.result-page p{font-size:14px;opacity:.8;max-width:320px}.result-page a{color:#93c5fd;font-weight:600;text-decoration:underline}.muted{color:var(--ink-3);font-size:13px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;gap:10px;color:var(--ink-3);text-align:center}.empty-state svg{opacity:.35;margin-bottom:4px}.empty-state p{font-size:14px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.order-row-compact{display:grid;grid-template-columns:88px minmax(0,1fr) auto auto auto;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}.mobile-nav-drawer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;pointer-events:none}.mobile-nav-drawer.open{pointer-events:auto}.mobile-nav-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:0;background:#0f172a73;opacity:0;transition:opacity .2s ease}.mobile-nav-drawer.open .mobile-nav-backdrop{opacity:1}.mobile-nav-panel{position:absolute;left:10px;right:10px;bottom:10px;max-height:min(84svh,720px);display:flex;flex-direction:column;gap:12px;padding:14px;border-radius:24px;background:linear-gradient(180deg,#2e4f31f5,#38613cf5 55%,#49784ef2);box-shadow:var(--shadow-xl);border:1px solid rgba(219,241,206,.22);transform:translateY(110%);transition:transform .24s ease;overflow:hidden}.mobile-nav-drawer.open .mobile-nav-panel{transform:translateY(0)}.mobile-nav-head{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#fff}.mobile-nav-head p{font-size:12px;color:#fff9;margin-bottom:2px}.mobile-nav-head h2{font-size:1.05rem}.mobile-nav-list{display:grid;gap:8px;overflow-y:auto;padding-right:4px;-webkit-overflow-scrolling:touch}.mobile-nav-item{display:grid;grid-template-columns:38px minmax(0,1fr) auto;align-items:center;gap:10px;width:100%;min-height:52px;padding:10px 12px;border-radius:16px;background:#ffffff1f;color:#fff;text-align:left}.mobile-nav-item.active{background:linear-gradient(135deg,#6aa960,#4f8f54);box-shadow:0 8px 20px #4f8f5452}.mobile-nav-icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center}.mobile-nav-text{display:flex;flex-direction:column;gap:2px;min-width:0}.mobile-nav-text b{font-size:13px;line-height:1.2}.mobile-nav-text small{font-size:11px;line-height:1.35;color:#ffffffa6}.mobile-nav-logout{width:100%;min-height:52px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:16px;background:#ffffff24;color:#fff;font-weight:700}@media(max-width:1100px){.ov-row1{grid-template-columns:240px 1fr}.ov-row2{grid-template-columns:1fr 1fr}}@media(max-width:900px){:root{--sidebar-w: 0px}.sidebar{display:none}.topbar-menu-btn{display:inline-flex}.workspace{grid-column:1 / -1}.workspace-body{padding:14px}.topbar{padding:10px 14px}.account-create{grid-template-columns:1fr 1fr}.ov-row1{grid-template-columns:1fr}.ov-metrics-col{flex-direction:row}.ov-metric-card{flex:1}.ov-row2{grid-template-columns:1fr}}@media(max-width:640px){.ov-header{flex-direction:column;align-items:flex-start}.ov-period-tabs{width:100%}.ov-period-btn{flex:1;text-align:center;padding:7px 8px;font-size:12px}.ov-metrics-col{flex-direction:column}.ov-metric-value{font-size:1.35rem}.ov-pie-legend,.orders-grid,.qr-grid,.account-grid,.menu-grid{grid-template-columns:1fr}.account-create{grid-template-columns:1fr;padding:12px}.menu-add-form{grid-template-columns:1fr}.image-picker{width:100%;height:104px}.qr-card{grid-template-columns:84px minmax(0,1fr)}.qr-card img{width:84px;height:84px}.customer-shell{max-width:100%}.topbar-actions .btn{padding:8px 10px;font-size:13px}}
