@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+Thai:wght@400;500;600;700;800&family=Prompt:wght@400;500;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+Thai:wght@400;700;800;900&family=Prompt:wght@400;700;800;900&display=swap);:root{--sky:#c3eefa;--sky-light:#e8f8fe;--sky-mid:#9ddff5;--sky-dark:#5bc8e8;--sky-deep:#2aa8cc;--white:#fff;--gray-50:#f8fafb;--gray-100:#eef2f5;--gray-200:#dde4ea;--gray-300:#c4cdd5;--gray-500:#8a98a5;--gray-700:#4a5568;--gray-900:#1a2332;--green:#4caf87;--green-light:#e8f8f1;--orange:#ff8c42;--orange-light:#fff3eb;--red:#ff5252;--red-light:#ffe9e9;--purple:#8b5cf6;--purple-light:#f3efff;--shadow-sm:0 1px 3px #236c8c14,0 1px 2px #236c8c0f;--shadow-md:0 4px 12px #236c8c1f,0 2px 4px #236c8c14;--shadow-lg:0 10px 30px #236c8c26,0 4px 8px #236c8c1a;--radius:12px;--radius-sm:8px;--radius-lg:16px;--radius-xl:20px;--font:"Prompt","Noto Sans Thai",sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#f8fafb;background:var(--gray-50);color:#1a2332;color:var(--gray-900);font-family:Prompt,Noto Sans Thai,sans-serif;font-family:var(--font);font-size:14px;line-height:1.6}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#9ddff5;background:var(--sky-mid);border-radius:3px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes ping{0%{opacity:1;transform:scale(1)}75%,to{opacity:0;transform:scale(2)}}.fade-in{animation:fadeIn .3s ease}.slide-in{animation:slideIn .3s ease}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:Prompt,Noto Sans Thai,sans-serif;font-family:var(--font);font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.btn-primary{background:#2aa8cc;background:var(--sky-deep);color:#fff}.btn-primary:hover{background:#2096b8;box-shadow:0 4px 12px #236c8c1f,0 2px 4px #236c8c14;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:#c3eefa;background:var(--sky);color:#2aa8cc;color:var(--sky-deep)}.btn-secondary:hover{background:#9ddff5;background:var(--sky-mid)}.btn-danger{background:#ff5252;background:var(--red);color:#fff}.btn-danger:hover{background:#e03333}.btn-success{background:#4caf87;background:var(--green);color:#fff}.btn-success:hover{background:#3a9a72}.btn-ghost{background:#0000;border:1.5px solid #dde4ea;border:1.5px solid var(--gray-200);color:#4a5568;color:var(--gray-700)}.btn-ghost:hover{background:#eef2f5;background:var(--gray-100)}.btn-sm{border-radius:6px;font-size:12px;padding:5px 10px}.btn-lg{border-radius:12px;border-radius:var(--radius);font-size:15px;padding:12px 24px}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.card{background:#fff;border:1px solid #c3eefa80;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #236c8c14,0 1px 2px #236c8c0f;box-shadow:var(--shadow-sm);overflow:hidden}.card-header{align-items:center;background:linear-gradient(135deg,#e8f8fe,#fff);background:linear-gradient(135deg,var(--sky-light) 0,#fff 100%);border-bottom:1px solid #eef2f5;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:16px 20px}.card-body{padding:20px}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:3px 8px}.badge-pending{background:#fff3eb;background:var(--orange-light);color:#ff8c42;color:var(--orange)}.badge-active{background:#e8f8fe;background:var(--sky-light);color:#2aa8cc;color:var(--sky-deep)}.badge-cooking{background:#f3efff;background:var(--purple-light);color:#8b5cf6;color:var(--purple)}.badge-done{background:#e8f8f1;background:var(--green-light);color:#4caf87;color:var(--green)}.badge-closed{background:#eef2f5;background:var(--gray-100);color:#8a98a5;color:var(--gray-500)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label{color:#4a5568;color:var(--gray-700);font-size:13px;font-weight:600}.form-input{background:#fff;border:1.5px solid #dde4ea;border:1.5px solid var(--gray-200);border-radius:8px;border-radius:var(--radius-sm);color:#1a2332;color:var(--gray-900);font-family:Prompt,Noto Sans Thai,sans-serif;font-family:var(--font);font-size:14px;padding:10px 14px;transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:#5bc8e8;border-color:var(--sky-dark);box-shadow:0 0 0 3px #c3eefa80;outline:none}.form-input::placeholder{color:#c4cdd5;color:var(--gray-300)}.data-table{border-collapse:collapse;width:100%}.data-table th{background:#e8f8fe;background:var(--sky-light);color:#8a98a5;color:var(--gray-500);font-size:12px;font-weight:600;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase}.data-table td{border-bottom:1px solid #eef2f5;border-bottom:1px solid var(--gray-100);font-size:13px;padding:12px 14px}.data-table tr:hover td,.tag{background:#e8f8fe;background:var(--sky-light)}.tag{align-items:center;border-radius:20px;color:#2aa8cc;color:var(--sky-deep);display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:4px 10px}.status-tabs-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.status-tab{align-items:center;background:#fff;border:1.5px solid #dde4ea;border:1.5px solid var(--gray-200);border-radius:20px;color:#4a5568;color:var(--gray-700);cursor:pointer;display:inline-flex;flex-shrink:0;font-family:Prompt,Noto Sans Thai,sans-serif;font-family:var(--font);font-size:13px;font-weight:500;gap:5px;padding:7px 14px;transition:all .2s ease;white-space:nowrap}.status-tab:hover{border-color:#5bc8e8;border-color:var(--tab-color,var(--sky-dark));color:#2aa8cc;color:var(--tab-color,var(--sky-deep))}.status-tab.active{background:#2aa8cc;background:var(--tab-color,var(--sky-deep));border-color:#2aa8cc;border-color:var(--tab-color,var(--sky-deep));box-shadow:0 2px 8px #00000026;color:#fff}.empty-state{color:#8a98a5;color:var(--gray-500);padding:48px 24px;text-align:center}.empty-state svg{height:48px;margin-bottom:12px;opacity:.4;width:48px}.spinner{animation:spin .8s linear infinite;border:2.5px solid #9ddff5;border-top-color:#2aa8cc;border:2.5px solid var(--sky-mid);border-radius:50%;border-top-color:var(--sky-deep);height:24px;width:24px}.divider{background:#eef2f5;background:var(--gray-100);height:1px;margin:16px 0}.sidebar{background:linear-gradient(180deg,#0a2540,#0d3155 60%,#0f3d6b);bottom:0;box-shadow:4px 0 20px #00000026;display:flex;flex-direction:column;left:0;position:fixed;top:0;width:220px;z-index:100}.sidebar-logo{align-items:center;border-bottom:1px solid #c3eefa1a;display:flex;gap:10px;padding:16px 16px 14px}.logo-title{color:#fff;font-size:15px;font-weight:800;line-height:1.2}.logo-sub{color:#c3eefa8c;font-size:10px;margin-top:2px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:3px;overflow-y:auto;padding:12px 10px}.nav-item{align-items:center;background:#0000;border:none;border-radius:10px;color:#c3eefa99;cursor:pointer;display:flex;gap:10px;padding:10px 11px;position:relative;text-align:left;transition:all .2s;width:100%}.nav-item:hover{background:#c3eefa14;color:var(--sky)}.nav-item.active{background:#c3eefa26;color:#fff}.nav-icon{flex-shrink:0;font-size:17px;text-align:center;width:24px}.nav-text{display:flex;flex-direction:column;gap:1px}.nav-label{font-family:var(--font);font-size:13px;font-weight:600}.nav-sub{font-size:10px;opacity:.55}.nav-indicator{background:var(--sky);border-radius:2px 0 0 2px;height:18px;position:absolute;right:0;top:50%;transform:translateY(-50%);width:3px}.sidebar-footer{border-top:1px solid #c3eefa1a;display:flex;flex-direction:column;gap:10px;padding:14px 10px 18px}.btn-queue{align-items:center;background:#c3eefa1a;border:1px solid #c3eefa33;border-radius:10px;color:var(--sky);cursor:pointer;display:flex;font-family:var(--font);font-size:12px;font-weight:600;gap:7px;justify-content:center;padding:9px;transition:all .2s}.btn-queue:hover{background:#c3eefa2e;transform:translateY(-1px)}.sidebar-time{font-feature-settings:"tnum";color:#fff;font-size:18px;font-weight:700;letter-spacing:1px;text-align:center}.logo-img{border:2px solid #c3eefa4d;border-radius:12px}.logo-img,.logo-img-wrap{flex-shrink:0;height:48px;width:48px}.logo-img-wrap{align-items:center;background:#fff;border-radius:12px;display:flex;justify-content:center;overflow:hidden}.logo-img{height:100%;object-fit:cover;width:100%}.modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a254080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:200}.modal-box{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0a25404d;display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow:hidden;width:100%}.modal-header{background:linear-gradient(135deg,var(--sky-light) 0,#fff 100%);border-bottom:1px solid var(--gray-100);flex-shrink:0;justify-content:space-between;padding:20px 24px}.modal-header,.modal-title-row{align-items:center;display:flex}.modal-title-row{gap:14px}.modal-queue{color:var(--sky-deep);font-size:32px;font-weight:800;line-height:1}.modal-title{color:var(--gray-900);font-size:18px;font-weight:700}.modal-sub{color:var(--gray-500);font-size:12px;margin-top:2px}.modal-close{align-items:center;background:var(--gray-100);border:none;border-radius:50%;color:var(--gray-700);cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-close:hover{background:var(--gray-200)}.modal-body{display:flex;flex:1 1;flex-direction:column;gap:16px;overflow-y:auto;padding:20px 24px}.modal-info-row{display:flex;flex-wrap:wrap;gap:8px}.info-chip{background:var(--gray-50);border:1px solid var(--gray-100);border-radius:8px;display:flex;flex-direction:column;gap:1px;padding:6px 12px}.info-label{color:var(--gray-500);font-size:10px;font-weight:600;text-transform:uppercase}.info-val{color:var(--gray-900);font-size:13px;font-weight:600}.slip-preview{background:var(--gray-50);border-radius:12px;padding:14px}.slip-img{border:1px solid var(--gray-200);border-radius:8px;max-height:200px;object-fit:contain;width:100%}.modal-section{display:flex;flex-direction:column;gap:10px}.section-head{align-items:center;display:flex;justify-content:space-between}.section-head h3{font-size:15px;font-weight:700}.items-list{gap:2px}.item-row,.items-list{display:flex;flex-direction:column}.item-row{background:var(--gray-50);border-radius:8px;gap:4px;padding:10px 12px}.item-main{align-items:center;display:flex;justify-content:space-between}.item-name{color:var(--gray-900);flex:1 1;font-size:13px;font-weight:600}.item-qty{color:var(--sky-deep);margin:0 8px}.item-price,.item-qty{font-size:13px;font-weight:700}.item-price{color:var(--gray-900);text-align:right}.item-opts{display:flex;flex-wrap:wrap;gap:4px}.item-note{color:var(--gray-500);font-size:11px}.total-row{align-items:center;background:var(--sky-light);border-radius:8px;display:flex;font-size:15px;font-weight:700;justify-content:space-between;margin-top:4px;padding:12px}.total-amount{color:var(--sky-deep);font-size:20px;font-weight:800}.edit-items{display:flex;flex-direction:column;gap:6px}.edit-item{align-items:center;background:var(--gray-50);border-radius:8px;display:flex;gap:8px;padding:8px 12px}.edit-item-name{flex:1 1;font-size:13px;font-weight:500}.qty-control{align-items:center;display:flex;gap:6px}.qty-control button{align-items:center;background:#fff;border:1.5px solid var(--sky-mid);border-radius:50%;color:var(--sky-deep);cursor:pointer;display:flex;font-size:14px;font-weight:700;height:26px;justify-content:center;transition:all .15s;width:26px}.qty-control button:hover{background:var(--sky)}.qty-control span{font-weight:700;min-width:20px;text-align:center}.edit-price{color:var(--gray-700);font-size:13px;font-weight:700;min-width:50px;text-align:right}.remove-btn{background:none;border:none;color:var(--red);cursor:pointer;font-size:14px;padding:2px 6px}.add-menu-section{margin-top:10px}.add-menu-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.add-menu-btn{align-items:center;background:#fff;border:1px solid var(--gray-200);border-radius:8px;cursor:pointer;display:flex;font-family:var(--font);font-size:12px;gap:4px;padding:5px 10px;transition:all .15s}.add-menu-btn:hover{background:var(--sky-light);border-color:var(--sky-dark)}.add-menu-btn span{color:var(--sky-deep);font-weight:600}.modal-actions{border-top:1px solid var(--gray-100);display:flex;flex-wrap:wrap;gap:8px;padding-top:8px}.tdm-box{animation:fadeIn .2s ease;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0a254040;display:flex;flex-direction:column;max-height:90vh;max-width:580px;overflow:hidden;width:100%}.tdm-header{align-items:flex-start;background:linear-gradient(135deg,var(--sky-light) 0,#fff 100%);border-bottom:1px solid var(--gray-100);display:flex;flex-shrink:0;justify-content:space-between;padding:20px 24px 14px}.tdm-title{color:var(--gray-900);font-size:22px;font-weight:800;margin-bottom:4px}.tdm-meta{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.tdm-status{font-size:13px;font-weight:700}.tdm-rounds{background:#fff3eb;border-radius:10px;color:#ff8c42;font-size:11px;font-weight:700;padding:2px 8px}.tdm-since{color:var(--gray-500);font-size:11px}.tdm-tabs{border-bottom:2px solid var(--gray-100);display:flex;flex-shrink:0;gap:0}.tdm-tab{background:#fff;border:none;border-bottom:2px solid #0000;color:var(--gray-500);cursor:pointer;flex:1 1;font-family:var(--font);font-size:13px;font-weight:500;margin-bottom:-2px;padding:10px;transition:all .2s}.tdm-tab.active{background:var(--sky-light);border-bottom-color:var(--sky-deep);color:var(--sky-deep);font-weight:700}.tdm-body{flex:1 1;overflow-y:auto;padding:16px 20px}.tdm-items-list{display:flex;flex-direction:column;gap:2px;margin-bottom:12px}.tdm-item-row{align-items:center;background:var(--gray-50);border-radius:8px;display:flex;gap:8px;padding:9px 12px}.tdm-item-info{flex:1 1;min-width:0}.tdm-item-name{color:var(--gray-900);font-size:13px;font-weight:600}.tdm-item-opts{display:flex;flex-wrap:wrap;gap:3px;margin-top:2px}.tdm-item-qty{color:var(--sky-deep);min-width:28px;text-align:center}.tdm-item-price,.tdm-item-qty{font-size:13px;font-weight:700}.tdm-item-price{color:var(--gray-700);min-width:50px;text-align:right}.tdm-grand-total{align-items:center;background:var(--sky-light);border-radius:10px;display:flex;font-size:14px;font-weight:700;justify-content:space-between;margin-bottom:12px;padding:12px 14px}.tdm-total-num{color:var(--sky-deep);font-size:24px;font-weight:800}.tdm-pay-info{display:flex;flex-direction:column;gap:4px}.tdm-pay-row{align-items:center;background:var(--gray-50);border-radius:6px;color:var(--gray-700);display:flex;font-size:12px;gap:8px;justify-content:space-between;padding:6px 10px}.tdm-rounds-list{display:flex;flex-direction:column;gap:10px}.tdm-round-card{border:1.5px solid var(--gray-200);border-radius:10px;overflow:hidden}.tdm-round-header{align-items:center;background:var(--gray-50);border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:10px 14px}.tdm-round-title{align-items:center;display:flex;gap:8px}.tdm-round-num{font-size:13px;font-weight:700}.tdm-round-time{color:var(--gray-500);font-size:11px}.tdm-round-right{align-items:center;display:flex;gap:10px}.tdm-round-total{color:var(--gray-900);font-size:14px;font-weight:800}.tdm-round-items{display:flex;flex-direction:column;gap:4px;padding:8px 14px}.tdm-round-item{align-items:center;color:var(--gray-700);display:flex;font-size:12px;gap:6px}.tdm-round-actions{background:var(--gray-50);display:flex;gap:6px;padding:8px 10px}.tdm-footer{background:#fff;border-top:1px solid var(--gray-100);display:flex;flex-shrink:0;flex-wrap:wrap;gap:8px;padding:14px 20px}.orders-page{max-width:1400px}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px}.page-title{color:var(--gray-900);font-size:20px;font-weight:700}.page-sub{color:var(--gray-500);font-size:12px;margin-top:2px}.stats-row{flex-wrap:wrap;gap:8px}.stat-pill,.stats-row{align-items:center;display:flex}.stat-pill{background:#fff;border:1.5px solid var(--gray-200);border-radius:10px;cursor:pointer;flex-direction:column;font-family:var(--font);min-width:64px;padding:6px 12px;transition:all .2s}.stat-pill:hover{border-color:var(--c,var(--sky-dark))}.stat-pill.selected{background:var(--sky);background:var(--c,var(--sky));border-color:var(--c,var(--sky));box-shadow:0 2px 8px #00000026;color:#fff}.stat-num{font-size:18px;font-weight:800;line-height:1}.stat-label{font-size:10px;margin-top:2px;opacity:.8}.table-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.table-card{background:#fff;border:2px solid var(--gray-100);border-radius:14px;box-shadow:0 1px 4px #0000000f;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:all .2s ease}.table-card:hover{border-color:var(--sc,var(--sky-mid));box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.table-card.urgent{animation:pulse 2s ease-in-out infinite;border-color:#ff8c42}.tc-head{align-items:center;display:flex;gap:8px;justify-content:space-between;padding:12px 14px}.tc-head-left{display:flex;flex-direction:column;gap:2px}.tc-name{color:var(--gray-900);font-weight:800}.tc-time{color:var(--gray-500);font-size:11px}.tc-head-right{align-items:flex-end;display:flex;flex-direction:column;gap:4px}.tc-status-badge{background:#fff;border:1.5px solid var(--sc,var(--sky-mid));border-radius:20px;color:var(--sky-deep);color:var(--sc,var(--sky-deep));font-size:12px;font-weight:700;padding:3px 8px;white-space:nowrap}.tc-multi-badge{background:#fff3eb;border-radius:10px;color:#ff8c42;font-size:10px;font-weight:700;padding:2px 7px}.tc-items{border-bottom:1px solid var(--gray-100);display:flex;flex:1 1;flex-direction:column;gap:3px;min-height:56px;padding:8px 14px 6px}.tc-item{align-items:center;display:flex;justify-content:space-between}.tc-item-name{color:var(--gray-700);flex:1 1;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tc-item-qty{color:var(--sky-deep);flex-shrink:0;font-size:12px;font-weight:700;margin-left:8px}.tc-item.more{color:var(--gray-500);font-size:11px;justify-content:flex-start}.tc-foot{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;padding:6px 14px}.tc-total{color:var(--gray-900);font-size:18px;font-weight:800}.tc-pay{color:var(--gray-500);font-size:12px}.tc-actions{background:var(--gray-50);flex-wrap:wrap;gap:6px;padding:8px 10px}.loading-center{align-items:center;color:var(--gray-500);display:flex;flex-direction:column;gap:16px;justify-content:center;padding:80px}.menu-page{max-width:1300px}.menu-main-tabs{background:#fff;border:1px solid var(--gray-100);border-radius:12px;box-shadow:var(--shadow-sm);display:flex;gap:0;margin-bottom:20px;padding:6px;width:fit-content}.main-tab{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--gray-500);cursor:pointer;display:flex;font-family:var(--font);font-size:13px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.main-tab:hover{background:var(--gray-50);color:var(--gray-900)}.main-tab.active{background:var(--sky-light);color:var(--sky-deep);font-weight:700}.main-tab-icon{font-size:16px}.main-tab-count{background:var(--gray-100);border-radius:10px;color:var(--gray-500);font-size:11px;font-weight:700;padding:1px 7px}.main-tab.active .main-tab-count{background:var(--sky);color:#fff}.cat-filter-bar{border-bottom:1px solid var(--gray-100);display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px;padding-bottom:16px}.cat-filter-btn{align-items:center;background:#fff;border:1.5px solid var(--gray-200);border-radius:20px;color:var(--gray-700);cursor:pointer;display:flex;font-family:var(--font);font-size:12px;font-weight:500;gap:6px;padding:6px 14px;transition:all .2s;white-space:nowrap}.cat-filter-btn span{background:var(--gray-100);border-radius:8px;color:var(--gray-500);font-size:11px;font-weight:700;padding:0 5px}.cat-filter-btn:hover{border-color:var(--sky-dark)}.cat-filter-btn.active{background:var(--sky-deep);border-color:var(--sky-deep);color:#fff}.cat-filter-btn.active span{background:#ffffff40;color:#fff}.menu-form-panel{background:#fff;border:2px solid var(--sky-mid);border-radius:14px;box-shadow:0 4px 20px #c3eefa66;margin-bottom:20px}.form-row-2{grid-gap:14px;gap:14px}.required{color:var(--red)}.og-checkbox-grid{display:flex;flex-wrap:wrap;gap:8px}.og-checkbox-item{align-items:center;border:1.5px solid var(--gray-200);border-radius:10px;cursor:pointer;display:flex;gap:8px;padding:8px 14px;transition:all .15s}.og-checkbox-item.checked{background:var(--sky-light);border-color:var(--sky-deep)}.og-checkbox-item input{display:none}.og-cb-info{display:flex;flex-direction:column;gap:1px}.og-cb-name{font-size:13px;font-weight:600}.og-cb-tag{color:var(--gray-500);font-size:10px}.available-toggle{align-items:center;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:10px}.available-toggle input{cursor:pointer;height:16px;width:16px}.menu-cards-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.menu-card{background:#fff;border:1.5px solid var(--gray-100);border-radius:12px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;transition:all .2s}.menu-card:hover{border-color:var(--sky-mid);box-shadow:var(--shadow-md);transform:translateY(-2px)}.menu-card.unavailable{opacity:.55}.menu-card-img{background:var(--sky-light);height:140px;overflow:hidden;position:relative}.menu-card-img img{height:100%;object-fit:cover;width:100%}.menu-card-img-placeholder{font-size:48px;height:100%}.menu-card-img-placeholder,.unavailable-overlay{align-items:center;display:flex;justify-content:center}.unavailable-overlay{background:#00000080;color:#fff;font-size:14px;font-weight:700;inset:0;position:absolute}.menu-card-body{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:12px}.menu-card-name{color:var(--gray-900);font-size:14px;font-weight:700;line-height:1.3}.menu-card-desc{color:var(--gray-500);font-size:11px;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-card-cat{color:var(--sky-deep);font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.menu-card-opts{display:flex;flex-wrap:wrap;gap:3px;margin-top:2px}.menu-card-footer{align-items:center;border-top:1px solid var(--gray-100);display:flex;justify-content:space-between;margin-top:auto;padding-top:8px}.menu-card-price{color:var(--sky-deep);font-size:18px;font-weight:800}.menu-card-actions{align-items:center;display:flex;gap:4px}.toggle-btn{border:none;border-radius:6px;cursor:pointer;font-family:var(--font);font-size:11px;font-weight:700;padding:4px 8px;transition:all .15s}.toggle-btn.on{background:var(--green-light);color:var(--green)}.toggle-btn.off{background:var(--red-light);color:var(--red)}.toggle-btn:hover{transform:scale(1.05)}.icon-btn{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:13px;height:28px;justify-content:center;transition:all .15s;width:28px}.icon-btn.edit:hover{background:var(--sky-light)}.icon-btn.del:hover{background:var(--red-light)}.simple-section{gap:0}.cat-list,.simple-section{display:flex;flex-direction:column}.cat-list-item{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;gap:12px;padding:12px 20px}.cat-list-item:last-child{border:none}.cat-list-icon{font-size:20px}.cat-list-name{flex:1 1;font-size:14px;font-weight:600}.cat-list-count{background:var(--gray-100);border-radius:10px;color:var(--gray-500);font-size:12px;padding:2px 8px}.og-list{display:flex;flex-direction:column}.og-list-item{border-bottom:1px solid var(--gray-100);padding:14px 20px}.og-list-item:last-child{border:none}.og-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.og-list-name{font-size:14px;font-weight:700}.og-tag{background:var(--sky-light);border-radius:8px;color:var(--sky-deep);font-size:11px;font-weight:600;padding:2px 8px}.og-tag.required{background:var(--red-light);color:var(--red)}.og-tag.optional{background:var(--green-light);color:var(--green)}.og-list-options{display:flex;flex-wrap:wrap;gap:6px}.og-option-chip{background:var(--gray-100);border-radius:20px;color:var(--gray-700);font-size:12px;font-weight:500;padding:4px 10px}.members-page{max-width:1300px}.member-form-panel{background:#fff;border:2px solid var(--sky-mid);border-radius:14px;box-shadow:0 4px 20px #c3eefa4d;margin-bottom:20px}.form-panel-body{display:flex;flex-direction:column;gap:0}.member-search{align-items:center;display:flex;gap:12px;margin-bottom:14px}.member-table-wrap{overflow-x:auto}.codes-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.code-card{background:#fff;border:2px solid var(--sky-mid);border-radius:14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:8px;padding:18px;transition:all .2s}.code-card.inactive{border-color:var(--gray-200);opacity:.55}.code-card-top{align-items:center;display:flex;justify-content:space-between}.code-badge{background:var(--sky-light);border-radius:8px;color:var(--sky-deep);font-family:monospace;font-size:18px;font-weight:800;letter-spacing:2px;padding:6px 14px}.code-name{color:var(--gray-900);font-size:14px;font-weight:600}.code-value{color:var(--gray-900);font-size:22px;font-weight:800}.code-value span{font-weight:500}.code-stats,.code-value span{color:var(--gray-500);font-size:12px}.code-actions{display:flex;gap:8px;margin-top:4px}.rewards-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.reward-card{align-items:center;background:#fff;border:1.5px solid var(--gray-100);border-radius:14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:6px;padding:18px;text-align:center}.reward-icon{font-size:40px}.reward-name{font-size:15px;font-weight:700}.reward-desc{color:var(--gray-500);font-size:12px}.reward-points{color:var(--sky-deep);font-size:22px;font-weight:800}.reward-stock{background:var(--orange-light);border-radius:10px;color:var(--orange);font-size:12px;font-weight:600;padding:2px 8px}.member-detail-modal{animation:fadeIn .2s ease;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:580px;overflow-y:auto;width:100%}.mdm-header{align-items:flex-start;background:var(--sky-light);border-bottom:1px solid var(--gray-100);border-radius:20px 20px 0 0;display:flex;justify-content:space-between;padding:20px 24px}.mdm-name{font-size:20px;font-weight:800}.mdm-nick{font-size:16px;font-weight:500}.mdm-nick,.mdm-phone{color:var(--gray-500)}.mdm-phone{font-size:14px;margin-top:2px}.mdm-stats{border-bottom:1px solid var(--gray-100);display:flex;gap:0}.mdm-stat{border-right:1px solid var(--gray-100);flex:1 1;padding:16px;text-align:center}.mdm-stat:last-child{border-right:none}.mdm-stat-val{font-size:24px;font-weight:800}.mdm-stat-label{color:var(--gray-500);font-size:11px;margin-top:2px}.mdm-adjust{background:var(--gray-50)}.mdm-adjust,.mdm-section{border-bottom:1px solid var(--gray-100);padding:16px 24px}.mdm-log{display:flex;flex-direction:column;gap:4px}.mdm-log-item{align-items:center;background:var(--gray-50);border-radius:8px;display:flex;font-size:12px;gap:8px;padding:6px 10px}.mdm-log-type{font-size:16px;text-align:center;width:20px}.mdm-order-item{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;font-size:13px;justify-content:space-between;padding:8px 0}.vouchers-page{max-width:1200px}.form-row-2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.form-row-3{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr}.voucher-form-panel{background:#fff;border:2px solid var(--sky-mid);border-radius:14px;box-shadow:0 4px 20px #c3eefa4d;margin-bottom:20px}.form-panel-header{align-items:center;background:var(--sky-light);border-bottom:1px solid var(--gray-100);border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:14px 20px}.form-panel-header h3{font-size:15px;font-weight:700}.form-panel-body{padding:20px}.template-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(270px,1fr))}.template-card{background:#fff;border:2px solid var(--sky-mid);border-radius:16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px;padding:20px;transition:all .2s}.template-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.template-card.inactive{opacity:.5}.tc-header{align-items:center;display:flex;justify-content:space-between}.tc-discount{color:#c8102e;font-size:28px;font-weight:900}.tc-name{font-size:16px;font-weight:700}.tc-desc{color:var(--gray-500);font-size:12px}.tc-meta{display:flex;gap:8px}.tc-meta span{background:var(--sky-light);border-radius:20px;color:var(--sky-deep);font-size:11px;font-weight:600;padding:3px 9px}.tc-stats{border:1px solid var(--gray-100);border-radius:10px;display:flex;overflow:hidden}.tc-stat{border-right:1px solid var(--gray-100);flex:1 1;padding:10px 6px;text-align:center}.tc-stat:last-child{border:none}.tc-stat-num{font-size:20px;font-weight:800}.tc-stat-label{color:var(--gray-500);font-size:10px}.tc-actions{display:flex;gap:8px}.qr-single-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-width:380px;padding:20px;width:100%}.qsm-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.qsm-header h3{font-size:16px;font-weight:700}.print-voucher-single{align-items:center;background:#fff;border:3px dashed #c8102e;border-radius:16px;display:flex;flex-direction:column;gap:8px;padding:20px;text-align:center}.pvs-top{width:100%}.pvs-title{color:#c8102e;font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.pvs-discount{color:#333;font-size:32px;font-weight:900;margin-top:4px}.pvs-qr{border-radius:10px;height:200px;margin:4px 0;width:200px}.pvs-code{color:#666;font-family:monospace;font-size:11px;font-weight:700;letter-spacing:2px}.pvs-expire{color:#888;font-size:11px}.pvs-note{background:#fff5f5;border-radius:8px;color:#c8102e;font-size:11px;font-weight:700;padding:6px 12px;width:100%}@media print{body *{visibility:hidden}.print-voucher-single,.print-voucher-single *{visibility:visible}.print-voucher-single{border:3px dashed #c8102e!important;left:50%;position:fixed;top:20mm;transform:translateX(-50%)}}.pvs-sub{color:#888;font-size:11px}.reports-page{max-width:1100px}.date-range-row{margin-bottom:0}.preset-btn{background:#fff;border:1.5px solid var(--gray-200);border-radius:20px;color:var(--gray-700);cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600;padding:5px 14px;transition:all .2s;white-space:nowrap}.preset-btn.active,.preset-btn:hover{background:var(--sky-light);border-color:var(--sky-dark);color:var(--sky-deep)}.date-sep{background:var(--gray-200);height:28px;margin:0 4px;width:1px}.report-cards{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));margin-bottom:20px}.report-card{background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-lg);border-top:4px solid #0000;box-shadow:var(--shadow-sm);padding:18px;text-align:center}.rc-icon{font-size:28px;margin-bottom:6px}.rc-value{color:var(--gray-900);font-size:26px;font-weight:800;line-height:1}.rc-label{color:var(--gray-500);font-size:11px;margin-top:4px}.report-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.rank-row{align-items:center;border-bottom:1px solid var(--gray-100);display:flex;gap:10px;padding:8px 0}.rank-row:last-child{border:none}.rank-num{align-items:center;background:var(--sky-light);border-radius:50%;color:var(--sky-deep);display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:22px;justify-content:center;width:22px}.rank-name{flex:1 1;font-size:13px;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rank-bar-wrap{background:var(--gray-100);border-radius:3px;flex-shrink:0;height:6px;overflow:hidden;width:80px}.rank-bar{background:var(--sky-dark);border-radius:3px;height:100%;transition:width .5s ease}.rank-qty{color:var(--sky-deep);font-weight:700;min-width:50px}.rank-qty,.rank-rev{flex-shrink:0;font-size:12px;text-align:right}.rank-rev{color:var(--gray-500);min-width:55px}.queue-display{background:linear-gradient(160deg,#0a2540,#0d3155 60%,#0f3d6b);color:#fff;display:flex;flex-direction:column;font-family:var(--font);min-height:100vh}.qd-header{align-items:center;background:#c3eefa12;border-bottom:1px solid #c3eefa1f;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:18px 40px}.qd-brand{color:var(--sky);font-size:20px;font-weight:700}.qd-time{font-feature-settings:"tnum";color:#fff;font-size:34px;font-weight:800;letter-spacing:2px}.qd-stats{display:flex;gap:12px}.qd-stat{background:#c3eefa1a;border:1px solid #c3eefa33;border-radius:12px;padding:8px 18px;text-align:center}.qd-stat.cooking{background:#8b5cf633;border-color:#8b5cf666}.qd-stat-num{color:var(--sky);display:block;font-size:26px;font-weight:800}.qd-stat-label{font-size:11px;opacity:.65}.qd-body{gap:24px;overflow-y:auto;padding:28px 40px}.qd-body,.qd-empty{display:flex;flex:1 1;flex-direction:column}.qd-empty{align-items:center;gap:10px;justify-content:center}.qd-empty-icon{font-size:72px}.qd-empty h2{color:var(--sky);font-size:28px;font-weight:700}.qd-empty p{font-size:16px;opacity:.55}.qd-section{display:flex;flex-direction:column;gap:12px}.qd-section-title{align-items:center;color:#c3eefa80;display:flex;font-size:12px;font-weight:700;gap:8px;letter-spacing:2px;text-transform:uppercase}.cooking-title{color:#c4b5fd}.pulse-dot{animation:ping 1.5s ease-in-out infinite;background:#a78bfa;border-radius:50%;flex-shrink:0;height:8px;width:8px}.qd-featured-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.qd-waiting-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.queue-ticket{animation:fadeIn .4s ease;background:#c3eefa12;border:1px solid #c3eefa26;border-radius:14px;display:flex;flex-direction:column;gap:5px;padding:14px;transition:all .3s}.queue-ticket.featured{background:#8b5cf62e;border-color:#8b5cf680;box-shadow:0 0 28px #8b5cf633;padding:18px}.qt-table-name{color:#fff;font-size:22px;font-weight:800;line-height:1}.queue-ticket.featured .qt-table-name{color:#e9d5ff;font-size:30px}.qt-source{align-self:flex-start;background:#c3eefa26;border-radius:6px;color:var(--sky);font-size:10px;font-weight:700;padding:2px 8px}.qt-items{display:flex;flex-direction:column;gap:2px}.qt-item{color:#fff9;font-size:11px}.queue-ticket.featured .qt-item{font-size:13px}.qt-cooking-badge{background:#8b5cf64d;border-radius:8px;color:#c4b5fd;font-size:12px;font-weight:700;margin-top:6px;padding:4px 10px;text-align:center}.qt-position{color:#c3eefa66;font-size:10px;margin-top:4px}.qd-footer{border-top:1px solid #c3eefa14;color:#c3eefa66;font-size:12px;padding:14px;text-align:center}.cl-root{align-items:center;background:#f5f0e8;display:flex;font-family:Prompt,Noto Sans Thai,sans-serif;justify-content:center;min-height:100vh;padding:0}.cl-card{background:#fff;max-width:420px;min-height:100vh}.cl-card,.cl-hero{align-items:center;display:flex;flex-direction:column;overflow:hidden;position:relative;width:100%}.cl-hero{background:#c8102e;min-height:260px;padding:32px 24px 40px}.cl-deco{background:#ffc8002e;border-radius:50%;position:absolute}.cl-deco-tl{height:120px;left:-30px;top:-30px;width:120px}.cl-deco-tr{background:#ffc80038;height:80px;right:-10px;top:10px;width:80px}.cl-deco-bl{background:#ffffff14;bottom:-20px;height:100px;left:20px;width:100px}.cl-sun{animation:spin-slow 8s linear infinite;font-size:36px;position:absolute;right:18px;top:12px}@keyframes spin-slow{to{transform:rotate(1turn)}}.cl-shop-name{color:#ffffffb3;font-size:11px;font-weight:700;letter-spacing:3px;margin-bottom:8px;text-transform:uppercase;z-index:1}.cl-mascot-wrap{align-items:center;animation:bounce 2s ease-in-out infinite;display:flex;flex-direction:column;z-index:1}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.cl-mascot{align-items:center;background:#fff;border:5px solid gold;border-radius:50%;box-shadow:0 8px 32px #00000040;display:flex;font-size:80px;height:140px;justify-content:center;width:140px}.cl-mascot-text{color:gold;font-size:28px;font-weight:900;letter-spacing:1px;margin-top:8px;text-shadow:2px 2px 0 #c8102e,-1px -1px 0 #000}.cl-queue-badge{background:gold;border-bottom:2px solid #e6c200;color:#333;font-size:13px;font-weight:700;padding:8px 20px;text-align:center;width:100%}.cl-main-actions{padding:24px 20px 12px;width:100%}.cl-btn-order{background:#c8102e;border:none;border-radius:50px;box-shadow:0 6px 20px #c8102e66;color:#fff;cursor:pointer;font-family:Prompt,sans-serif;font-size:18px;font-weight:800;letter-spacing:1px;padding:18px;transition:all .2s;width:100%}.cl-btn-order:hover{box-shadow:0 8px 28px #c8102e80;transform:scale(1.03)}.cl-member-row{display:flex;flex-direction:column;gap:8px;padding:0 20px 16px;width:100%}.cl-btn-member{background:#fff;border:2px solid #ddd;border-radius:50px;color:#333;cursor:pointer;font-family:Prompt,sans-serif;font-size:14px;font-weight:700;padding:12px 20px;transition:all .2s;width:100%}.cl-btn-member.active,.cl-btn-member:hover{background:#fff5f6;border-color:#c8102e;color:#c8102e}.cl-btn-register{background:gold;border:2px solid gold;border-radius:50px;box-shadow:0 3px 10px #ffd70066;color:#333;cursor:pointer;font-family:Prompt,sans-serif;font-size:14px;font-weight:800;padding:12px 20px;transition:all .2s;width:100%}.cl-btn-register:hover{transform:scale(1.02)}.cl-social-label{color:#aaa;font-size:12px;font-weight:600;letter-spacing:1px;margin-bottom:10px}.cl-social-row{gap:10px;padding:0 20px 16px}.cl-social-btn,.cl-social-row{display:flex;justify-content:center}.cl-social-btn{align-items:center;border-radius:50px;flex:1 1;font-family:Prompt,sans-serif;font-size:13px;font-weight:700;gap:6px;padding:8px 16px;text-decoration:none;transition:all .2s}.cl-social-icon{font-size:15px;font-weight:900}.cl-social-btn.fb{background:#1877f2;color:#fff}.cl-social-btn.tt{background:#000;color:#fff}.cl-social-btn.line{background:#00c300;color:#fff}.cl-social-btn:hover{transform:scale(1.05)}.cl-btn-feedback{background:#fff;border:2px dashed #c8102e;border-radius:14px;color:#c8102e;cursor:pointer;font-family:Prompt,sans-serif;font-size:14px;font-weight:700;margin-bottom:10px;padding:12px;transition:all .2s;width:calc(100% - 40px)}.cl-btn-feedback:hover{background:#fff5f6}.cl-btn-queue{background:#f5f5f5;border:none;border-radius:14px;color:#555;cursor:pointer;font-family:Prompt,sans-serif;font-size:13px;font-weight:600;margin-bottom:24px;padding:10px;width:calc(100% - 40px)}.cl-form-card{justify-content:flex-start;padding:24px 24px 32px}.cl-back{align-self:flex-start;background:none;border:none;color:#999;cursor:pointer;font-family:Prompt,sans-serif;font-size:14px;font-weight:600;margin-bottom:16px;padding:0}.cl-back:hover{color:#333}.cl-form-title{color:#c8102e;font-size:24px;font-weight:900;margin-bottom:4px;width:100%}.cl-form-sub{color:#888;font-size:14px;margin-bottom:24px;width:100%}.cl-form-group{margin-bottom:14px;width:100%}.cl-form-group label{color:#555;display:block;font-size:13px;font-weight:700;margin-bottom:5px}.cl-input{background:#fafafa;border:2px solid #eee;border-radius:12px;box-sizing:border-box;color:#333;font-family:Prompt,sans-serif;font-size:14px;padding:12px 16px;transition:all .2s;width:100%}.cl-input:focus{background:#fff;border-color:#c8102e;outline:none}.cl-form-row2{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;width:100%}.cl-btn-submit{background:#c8102e;border:none;border-radius:50px;box-shadow:0 4px 16px #c8102e59;color:#fff;cursor:pointer;font-family:Prompt,sans-serif;font-size:16px;font-weight:800;margin-top:8px;padding:15px;transition:all .2s;width:100%}.cl-btn-submit:hover:not(:disabled){transform:scale(1.02)}.cl-btn-submit:disabled{cursor:not-allowed;opacity:.6}.cl-form-switch{color:#888;font-size:13px;margin-top:16px;text-align:center}.cl-form-switch span{color:#c8102e;cursor:pointer;font-weight:700;text-decoration:underline}.cl-member-profile{margin-bottom:16px;text-align:center;width:100%}.cl-profile-avatar{align-items:center;background:linear-gradient(135deg,#c8102e,#ff6b6b);border-radius:50%;box-shadow:0 4px 16px #c8102e4d;color:#fff;display:flex;font-size:32px;font-weight:900;height:72px;justify-content:center;margin:0 auto 10px;width:72px}.cl-profile-name{font-size:20px;font-weight:800}.cl-profile-nick{color:#888;font-size:14px}.cl-profile-phone{color:#aaa;font-size:13px;margin-top:4px}.cl-points-card{background:linear-gradient(135deg,#c8102e,#e63950);border-radius:16px;box-shadow:0 6px 20px #c8102e4d;color:#fff;margin-bottom:16px;padding:20px;text-align:center;width:100%}.cl-points-num{font-size:48px;font-weight:900;line-height:1}.cl-points-label{font-size:16px;font-weight:700;margin-top:4px}.cl-points-sub{font-size:12px;margin-top:4px;opacity:.75}.cl-member-stats{display:flex;gap:12px;margin-bottom:8px;width:100%}.cl-mstat{background:#f8f8f8;border-radius:12px;flex:1 1;padding:14px;text-align:center}.cl-mstat-num{color:#333;font-size:20px;font-weight:800}.cl-mstat-label{color:#888;font-size:11px;margin-top:2px}.cl-btn-logout{background:none;border:1px solid #ddd;border-radius:50px;color:#aaa;cursor:pointer;font-family:Prompt,sans-serif;font-size:13px;margin-top:8px;padding:10px;width:100%}.cl-star-row{display:flex;gap:8px;margin-bottom:8px}.cl-star{background:none;border:none;color:#ddd;cursor:pointer;font-size:40px;padding:4px;transition:all .15s}.cl-star.active{color:gold;transform:scale(1.1)}.cl-rating-text{color:#333;font-size:18px;font-weight:700;margin-bottom:16px;min-height:28px}.cl-feedback-done{align-items:center;display:flex;flex-direction:column;padding:32px 0;text-align:center;width:100%}.cl-vouchers-section{margin-bottom:8px;width:100%}.cl-vouchers-title{color:#333;font-size:14px;font-weight:700;margin-bottom:8px}.cl-voucher-item{align-items:center;background:linear-gradient(135deg,#fff5f5,#fff);border:2px solid #fcc;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:6px;padding:10px 14px}.cl-voucher-left{flex:1 1}.cl-voucher-name{color:#333;font-size:13px;font-weight:700}.cl-voucher-desc{color:#888;font-size:11px;margin-top:2px}.cl-voucher-expire{color:#c8102e;font-size:10px;font-weight:600;margin-top:2px}.cl-voucher-value{color:#c8102e;flex-shrink:0;font-size:22px;font-weight:900;margin-left:12px}.customer-page{background:var(--gray-50);font-family:var(--font);margin:0 auto;max-width:480px;min-height:100vh;padding-bottom:80px}.shop-header{align-items:center;background:linear-gradient(135deg,#0a2540,#0d3155);display:flex;gap:12px;justify-content:space-between;padding:16px 20px;position:sticky;top:0;z-index:50}.shop-name{color:var(--sky);flex:1 1;font-size:16px;font-weight:700}.shop-table{background:#c3eefa1a;border-radius:20px;color:#c3eefab3;font-size:12px;padding:4px 10px}.header-actions{gap:8px}.cart-btn,.header-actions{align-items:center;display:flex}.cart-btn{background:var(--sky);border:none;border-radius:20px;color:#0a2540;cursor:pointer;font-family:var(--font);font-size:13px;font-weight:700;gap:6px;padding:6px 14px;transition:all .2s}.cart-badge{align-items:center;background:#0a2540;border-radius:50%;color:var(--sky);display:flex;font-size:11px;height:18px;justify-content:center;width:18px}.cat-tabs{-webkit-overflow-scrolling:touch;background:#fff;border-bottom:1px solid var(--gray-100);display:flex;gap:8px;overflow-x:auto;padding:12px 16px;position:sticky;top:54px;z-index:40}.cat-tabs::-webkit-scrollbar{display:none}.cat-tab{background:#fff;border:1.5px solid var(--gray-200);border-radius:20px;color:var(--gray-700);cursor:pointer;flex-shrink:0;font-family:var(--font);font-size:13px;font-weight:500;padding:6px 14px;transition:all .2s;white-space:nowrap}.cat-tab.active{background:var(--sky-deep);border-color:var(--sky-deep);color:#fff}.menu-grid{display:flex;flex-direction:column;gap:10px;padding:12px}.menu-item{align-items:center;background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius);box-shadow:var(--shadow-sm);cursor:pointer;display:flex;gap:12px;overflow:hidden;padding:10px;transition:all .2s}.menu-item:hover{border-color:var(--sky-mid);box-shadow:var(--shadow-md)}.menu-img-wrap{border-radius:10px;flex-shrink:0;height:70px;overflow:hidden;width:70px}.menu-img{height:100%;object-fit:cover;width:100%}.menu-img-placeholder{align-items:center;background:var(--sky-light);display:flex;font-size:28px;height:100%;justify-content:center;width:100%}.menu-info{flex:1 1;min-width:0}.menu-name{color:var(--gray-900);font-size:14px;font-weight:600}.menu-desc,.menu-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-desc{color:var(--gray-500);font-size:11px;margin-top:2px}.menu-price{color:var(--sky-deep);font-size:16px;font-weight:800;margin-top:4px}.menu-add-btn{align-items:center;background:var(--sky-deep);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:32px;justify-content:center;transition:all .2s;width:32px}.menu-add-btn:hover{background:#2096b8;transform:scale(1.1)}.cart-page,.payment-page{padding:16px}.cart-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.cart-header h2{font-size:18px;font-weight:700}.cart-items{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.cart-item{align-items:center;background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius);display:flex;justify-content:space-between;padding:12px}.cart-item-name{font-size:14px;font-weight:600}.cart-item-opts{display:flex;flex-wrap:wrap;gap:4px;margin:4px 0}.cart-item-price{color:var(--sky-deep);font-size:15px;font-weight:700}.cart-note,.cart-total{margin-bottom:16px}.cart-total{align-items:center;background:var(--sky-light);border-radius:var(--radius);display:flex;font-size:16px;font-weight:700;justify-content:space-between;padding:14px}.cart-total span:last-child{color:var(--sky-deep);font-size:22px;font-weight:800}.payment-methods{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.payment-method{align-items:center;background:#fff;border:2px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;display:flex;gap:14px;padding:14px 16px;transition:all .2s}.payment-method.selected{background:var(--sky-light);border-color:var(--sky-deep)}.pm-icon{font-size:28px}.pm-title{font-size:15px;font-weight:700}.pm-sub{color:var(--gray-500);font-size:12px;margin-top:2px}.qr-section{background:#fff;border-radius:var(--radius);margin-bottom:16px;padding:16px;text-align:center}.qr-image{height:180px;margin-bottom:12px;object-fit:contain;width:180px}.cash-warning{background:var(--orange-light);border:1px solid #ffd4b8;border-radius:var(--radius);color:#b85a00;font-size:13px;margin-bottom:16px;padding:12px 16px}.option-overlay{align-items:flex-end;animation:fadeIn .2s ease;background:#0a254099;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}.option-modal{animation:slideUp .3s ease;background:#fff;border-radius:20px 20px 0 0;max-height:90vh;max-width:480px;overflow-y:auto;padding:20px;width:100%}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.option-header{align-items:flex-start;display:flex;gap:10px;margin-bottom:8px}.option-header h3{flex:1 1;font-size:18px;font-weight:700}.option-price{color:var(--sky-deep);font-size:18px;font-weight:800}.option-desc{color:var(--gray-500);font-size:13px}.option-desc,.option-group{margin-bottom:16px}.og-title{align-items:center;display:flex;font-size:14px;font-weight:700;gap:8px;margin-bottom:8px}.required-badge{background:var(--red-light);border-radius:6px;color:var(--red);font-size:10px;padding:2px 7px}.og-options{display:flex;flex-direction:column;gap:6px}.og-option{align-items:center;border:1.5px solid var(--gray-200);border-radius:10px;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:10px 14px;transition:all .15s}.og-option.selected{background:var(--sky-light);border-color:var(--sky-deep);font-weight:600}.og-option input{display:none}.extra-price{color:var(--green);font-size:12px;font-weight:600;margin-left:auto}.customer-confirm{align-items:center;background:linear-gradient(135deg,#0a2540,#0d3155);display:flex;justify-content:center;min-height:100vh;padding:20px}.confirm-card{background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;max-width:360px;padding:40px 32px;text-align:center;width:100%}.confirm-icon{font-size:60px;margin-bottom:12px}.confirm-card h2{font-size:22px;font-weight:700;margin-bottom:16px}.confirm-queue{color:var(--gray-500);font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase}.confirm-num{color:var(--sky-deep);font-size:72px;font-weight:800;line-height:1}.confirm-table{color:var(--gray-700);font-size:16px}.confirm-table,.confirm-wait{font-weight:600;margin-bottom:12px}.confirm-wait{background:var(--sky-light);border-radius:20px;color:var(--sky-deep);font-size:13px;padding:8px 16px}.confirm-tips{background:var(--gray-50);border-radius:10px;color:var(--gray-500);font-size:13px;margin-bottom:24px;padding:10px}.voucher-section{background:#fff5f5;border:2px solid #fcc;border-radius:14px;margin-bottom:16px;padding:14px}.voucher-section-title{color:#c8102e;font-size:14px;font-weight:800;margin-bottom:10px}.voucher-choice{align-items:center;background:#fff;border:2px solid #eee;border-radius:10px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:6px;padding:10px 12px;transition:all .15s}.voucher-choice.selected{background:#fff0f0;border-color:#c8102e}.vc-left{flex:1 1}.vc-name{font-size:13px;font-weight:700}.vc-desc{color:#888;font-size:11px;margin-top:1px}.vc-expire{color:#c8102e;font-size:10px;font-weight:600;margin-top:2px}.vc-min{color:#888;font-size:10px}.vc-right{align-items:flex-end;display:flex;flex-direction:column;gap:4px;margin-left:12px}.vc-value{color:#c8102e;font-size:20px;font-weight:900}.vc-check{font-size:16px}.vc-clear{background:none;border:1px solid #fcc;border-radius:8px;color:#c8102e;cursor:pointer;font-family:var(--font);font-size:12px;font-weight:600;margin-top:4px;padding:6px;width:100%}.cart-total-box{background:var(--sky-light);border-radius:12px;display:flex;flex-direction:column;gap:6px;margin-bottom:16px;padding:12px 16px}.ct-row{align-items:center;color:var(--gray-700);display:flex;font-size:14px;justify-content:space-between}.ct-row.discount{color:#c8102e;font-weight:600}.ct-row.final{border-top:1px solid var(--sky-mid);color:var(--gray-900);font-size:18px;font-weight:800;margin-top:2px;padding-top:8px}.pos-layout{background:var(--gray-50);display:flex;min-height:100vh}.pos-main{flex:1 1;margin-left:240px;min-height:100vh;overflow-y:auto;padding:24px}@media (max-width:768px){.pos-main{margin-left:0;padding:16px}}
/*# sourceMappingURL=main.4d756820.css.map*/