:root{--accent: #5a9e5f;--accent-dark: #3d7a42;--accent-btn: linear-gradient(135deg, #5a9e5f 0%, #3d7a42 100%);--bg: #f5f5f0;--bg-outer: #d8e4d9;--surface: #ffffff;--surface2: #f8f8f4;--surface-sheet: #ffffff;--text-heading: #1c1c1c;--text-body: #3a3a3a;--text-muted: #888888;--text-price: #5a9e5f;--cat-active-bg: #4a8e4f;--tag-bg: #2a2a2a;--tag-fg: #ffffff;--border: rgba(0, 0, 0, .07);--divider: #f0f0eb;--shadow-card: 0 2px 16px rgba(0, 0, 0, .07);--shadow-sheet: 0 -8px 40px rgba(0, 0, 0, .18);--max-w: 560px;--radius-card: 22px;--radius-pill: 50px;--radius-sheet: 28px;--ease-standard: cubic-bezier(.4, 0, .2, 1);--ease-decelerate: cubic-bezier(0, 0, 0, 1);--ease-accelerate: cubic-bezier(.32, 0, .67, 0);--ease-spring-soft: cubic-bezier(.2, .8, .2, 1);--ease-spring-pop: cubic-bezier(.34, 1.56, .64, 1);--ease-apple: var(--ease-standard);--ease-bounce: var(--ease-spring-pop)}[data-theme=dark]{--accent: #6abf70;--accent-dark: #4caf50;--accent-btn: linear-gradient(135deg, #4caf50 0%, #388e3c 100%);--bg: #121812;--bg-outer: #0a0f0a;--surface: #1e261e;--surface2: #243024;--surface-sheet: #1e261e;--text-heading: #f0f4f0;--text-body: #c8d4c8;--text-muted: #7a9a7a;--text-price: #6abf70;--cat-active-bg: #388e3c;--tag-bg: #2e3e2e;--tag-fg: #c8f0c8;--border: rgba(255, 255, 255, .08);--divider: rgba(255, 255, 255, .06);--shadow-card: 0 2px 16px rgba(0, 0, 0, .35);--shadow-sheet: 0 -8px 40px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent;overscroll-behavior-y:contain}body{font-family:Outfit,sans-serif;background:var(--bg-outer);color:var(--text-body);overflow-x:hidden;min-height:100svh;-webkit-overflow-scrolling:touch;transition:background .5s var(--ease-apple),color .5s var(--ease-apple)}img{display:block;max-width:100%}button{cursor:pointer;border:none;background:none;font-family:inherit;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}input{font-family:inherit}ul,li{list-style:none}.view{display:none;flex-direction:column;min-height:100svh;width:100%;max-width:var(--max-w);margin:0 auto;background:var(--bg);position:relative;overflow-x:hidden;transition:background .5s var(--ease-apple);-webkit-overflow-scrolling:touch}.view.active{display:flex}@keyframes pageSlideIn{0%{transform:translate(100%) scale(.96);opacity:0}to{transform:translate(0) scale(1);opacity:1}}@keyframes pageSlideOut{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(-30%) scale(.96);opacity:0}}@keyframes pageSlideOutRight{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(100%) scale(.96);opacity:0}}@keyframes pageSlideInLeft{0%{transform:translate(-30%) scale(.96);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.page-entering{animation:pageSlideIn .22s var(--ease-decelerate) both}.page-leaving{animation:pageSlideOut .22s var(--ease-decelerate) both}.page-entering-back{animation:pageSlideInLeft .22s var(--ease-decelerate) both}.page-leaving-back{animation:pageSlideOutRight .22s var(--ease-decelerate) both}@media (min-width: 561px){.view{box-shadow:0 0 100px #00000059}}.top-bar{position:sticky;top:0;z-index:90;display:flex;justify-content:flex-end;align-items:center;gap:8px;padding:10px 16px 0;background:transparent;transition:background .4s var(--ease-apple),backdrop-filter .4s}.top-bar.scrolled{background:rgba(var(--bg-rgb, 245, 245, 240),.72);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px)}[data-theme=dark] .top-bar.scrolled{background:#121812b8}.theme-toggle{position:relative;width:28px;height:28px;border-radius:50%;background:#ffffffbf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.9);color:var(--text-heading);font-size:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #0000001f;transition:transform .06s var(--ease-spring-soft),background .15s,color .15s}.theme-toggle:active{transform:scale(.85);transition-duration:.04s}[data-theme=dark] .theme-toggle{background:#1e261ed9;border-color:#ffffff1f;color:var(--accent)}.top-cart-btn{position:relative;width:28px;height:28px;border-radius:50%;background:#ffffffbf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.9);color:var(--text-heading);font-size:13px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #0000001f;transition:transform .06s var(--ease-spring-soft),background .15s,color .15s}.top-cart-btn:active{transform:scale(.85);transition-duration:.04s}.top-cart-btn.has-items{color:#e91e8c}[data-theme=dark] .top-cart-btn{background:#1e261ed9;border-color:#ffffff1f;color:var(--text-heading)}[data-theme=dark] .top-cart-btn.has-items{color:#ff4da6}.cart-badge{position:absolute;top:-3px;right:-3px;background:#e91e8c;color:#fff;font-size:9px;font-weight:700;min-width:15px;height:15px;padding:0 3px;border-radius:8px;border:1.5px solid var(--bg);display:flex;align-items:center;justify-content:center;transition:transform .25s var(--ease-spring)}.cart-badge.hidden{display:none}@keyframes badgePop{0%,to{transform:scale(1)}50%{transform:scale(1.55)}}.cart-badge.pop{animation:badgePop .3s var(--ease-spring)}.hero-header{text-align:left;padding:0 18px 4px;margin-top:-10px;background:transparent;position:relative;z-index:1}.greeting{font-family:Playfair Display,serif;font-style:italic;font-size:11px;color:var(--accent);margin-bottom:0}.restaurant-name{font-family:Playfair Display,serif;font-size:18px;font-weight:700;color:var(--text-heading);letter-spacing:3px;line-height:1.1}.hero-header:before,.hero-header:after{display:none}.cat-section{padding:10px 0 4px}.cat-section-label{display:flex;justify-content:space-between;align-items:center;padding:0 18px 8px;font-size:10px;font-weight:700;letter-spacing:1.2px;color:var(--text-muted)}.swipe-hint{font-weight:500;color:var(--accent);font-size:9px;display:flex;align-items:center;gap:4px;animation:hintSwipe 2s infinite ease-in-out}@keyframes hintSwipe{0%{transform:translate(0)}50%{transform:translate(-4px)}to{transform:translate(0)}}.cat-scroll-wrap{overflow-x:auto;overflow-y:visible;scrollbar-width:none;padding:4px 0 2px}.cat-scroll-wrap::-webkit-scrollbar{display:none}.cat-cards{display:flex;gap:5px;padding:0 14px 8px;scroll-snap-type:x mandatory}.cat-card{flex-shrink:0;scroll-snap-align:start;width:60px;min-height:60px;background:var(--surface);border-radius:13px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 5px;box-shadow:var(--shadow-card);border:1.5px solid transparent;cursor:pointer;transition:transform .2s var(--ease-spring-soft),background .15s var(--ease-standard),box-shadow .15s var(--ease-standard),border-color .15s var(--ease-standard);will-change:transform}.cat-card:active{transform:scale(.92);transition:transform .05s var(--ease-standard)}.cat-card:not(:active):hover{transform:scale(1.04) translateY(-2px)}.cat-card.active{background:var(--cat-active-bg);border-color:var(--cat-active-bg);box-shadow:0 6px 24px #4a8e4f66,0 2px 8px #4a8e4f33;transform:scale(1.02)}.cat-card-icon{font-size:16px;color:var(--accent);transition:color .3s var(--ease-apple),transform .3s var(--ease-bounce)}.cat-card.active .cat-card-icon{color:#fffffff2;transform:scale(1.15)}.cat-card-label{font-size:8px;font-weight:700;text-align:center;color:var(--text-body);letter-spacing:.15px;line-height:1.1;transition:color .3s var(--ease-apple)}.cat-card.active .cat-card-label{color:#fff}.search-wrap{padding:6px 14px 4px}.search-bar{display:flex;align-items:center;gap:8px;background:var(--surface);border-radius:var(--radius-pill);padding:9px 14px;box-shadow:var(--shadow-card);border:1.5px solid transparent;transition:border-color .2s var(--ease-standard),box-shadow .2s var(--ease-standard),transform .2s var(--ease-spring-soft)}.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent),var(--shadow-card);transform:scale(1.015)}.search-icon{color:var(--text-muted);font-size:12px}.search-bar input{flex:1;border:none;outline:none;background:transparent;font-size:12px;color:var(--text-body)}.search-bar input::placeholder{color:var(--text-muted)}.section-bar{display:flex;align-items:center;justify-content:space-between;padding:1px 14px 6px;flex-wrap:wrap;gap:6px}.section-title{font-family:Playfair Display,serif;font-size:13px;font-weight:700;color:var(--text-heading)}.filter-group{display:flex;align-items:center;gap:6px}.filter-btn{padding:2px 7px;border-radius:var(--radius-pill);font-size:10px;font-weight:600;background:var(--surface);color:var(--text-muted);border:1.5px solid var(--border);transition:all .28s var(--ease-standard);will-change:transform}.filter-btn:active{transform:scale(.92);transition-duration:.1s}.filter-btn.active{background:var(--text-heading);color:#fff;border-color:var(--text-heading)}[data-theme=dark] .filter-btn.active{background:var(--accent);color:#0a0f0a;border-color:var(--accent)}.filter-btn i{font-size:9px;margin-right:2px}.filter-btn.veg-btn{color:#2e7d32}.filter-btn.veg-btn.active{background:#2e7d32;color:#fff;border-color:#2e7d32}.filter-btn.non-btn{color:#8d1c1c}.filter-btn.non-btn.active{background:#8d1c1c;color:#fff;border-color:#8d1c1c}.view-switch-pill{display:flex;align-items:center;gap:2px;background:var(--surface2);border:1.5px solid var(--border);padding:2px;border-radius:10px;margin-left:auto}.view-toggle{width:22px;height:20px;border-radius:50%;background:transparent;color:var(--text-muted);border:none;font-size:9px;display:flex;align-items:center;justify-content:center;transition:all .2s var(--ease-standard)}.view-toggle:active{transform:scale(.9)}.view-toggle i{transform:scale(.9);transition:transform .25s var(--ease-spring-soft)}.view-toggle.active{background:var(--text-heading);color:#fff}[data-theme=dark] .view-toggle.active{background:var(--accent);color:#0a0f0a}.empty-results{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:13px;line-height:1.6}.gallery-cat-hint{font-size:9px;font-weight:500;color:var(--accent);opacity:.8;margin-top:2px}.menu-sections{flex:1;padding:0 0 80px;touch-action:pan-y;will-change:transform}.list-section{margin:0 0 24px}.list-section-label{font-family:Playfair Display,serif;font-size:18px;font-weight:700;color:var(--text-heading);padding:6px 18px 10px}.dish-list{display:flex;flex-direction:column;gap:7px}.dish-row{display:flex;align-items:center;gap:9px;padding:8px 11px;background:var(--surface);border-radius:14px;border:1.2px solid var(--border);cursor:pointer;position:relative;overflow:hidden;transition:background .15s var(--ease-standard),transform .12s var(--ease-spring-soft),border-color .15s;opacity:0;transform:translate(-14px);animation:rowSlideIn .25s var(--ease-decelerate) forwards;will-change:transform,opacity}@keyframes rowSlideIn{0%{opacity:0;transform:translate(-14px)}to{opacity:1;transform:translate(0)}}.dish-row:active{background:color-mix(in srgb,var(--accent) 10%,var(--surface));border-color:var(--accent);transform:scale(.975);transition-duration:.08s}.dish-card-badge{position:absolute;top:8px;left:8px;font-size:9px;font-weight:800;letter-spacing:.6px;padding:2px 8px;border-radius:20px;pointer-events:none}.new-badge{background:#43a047;color:#fff}.best-badge{background:#f59e0b;color:#1a1a1a}.list-thumb-wrap{flex-shrink:0;width:90px;height:68px;border-radius:12px;overflow:hidden;background:var(--surface2);box-shadow:0 4px 10px #0000001a}.list-thumb{width:100%;height:100%;object-fit:contain;padding:2px;opacity:0;transition:opacity .4s ease-out,transform .4s var(--ease-spring-soft);transform:scale(.92);will-change:opacity,transform}.list-thumb.loaded{opacity:1;transform:scale(1)}.list-info{flex:1;min-width:0}.list-name{font-size:12px;font-weight:700;color:var(--text-heading);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.list-sub{font-size:9.5px;color:var(--text-muted);font-weight:400;margin-bottom:3px}.list-price{font-family:Playfair Display,serif;font-size:13px;font-weight:700;color:var(--accent)}.list-badge{background:#43a047;color:#fff;font-size:9px;font-weight:800;letter-spacing:.5px;padding:2px 7px;border-radius:20px;margin-left:8px;vertical-align:middle}.list-arrow{display:none}.list-card-wrap{margin:0 12px 8px;display:flex;flex-direction:column;gap:7px}.gallery-section{margin:0 0 24px}.gallery-section-label{font-family:Playfair Display,serif;font-size:18px;font-weight:700;color:var(--text-heading);padding:6px 18px 10px}.dish-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 14px}@media (min-width: 700px){.dish-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1024px){.dish-grid{grid-template-columns:repeat(4,1fr)}}.dish-gallery-card{background:var(--surface);border-radius:var(--radius-card);overflow:hidden;box-shadow:var(--shadow-card);cursor:pointer;padding-bottom:8px;text-align:center;opacity:0;transform:translateY(20px) scale(.96);animation:cardReveal .5s var(--ease-bounce) forwards;position:relative;transition:transform .3s var(--ease-bounce),box-shadow .3s var(--ease-apple);will-change:transform}@keyframes cardReveal{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.dish-gallery-card:not(:active):hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 32px #00000026}.dish-gallery-card:active{transform:scale(.94);box-shadow:var(--shadow-card);transition-duration:.08s}.gallery-img-wrap{width:100%;aspect-ratio:1.25;background:linear-gradient(160deg,#eef6ee,#dff0df);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;border-radius:14px}.gallery-img{width:80%;height:80%;object-fit:contain;opacity:0;transition:opacity .4s ease-out,transform .4s var(--ease-spring-soft);transform:scale(.92);will-change:opacity,transform}.gallery-img.loaded{opacity:1;transform:scale(1)}.gallery-new-badge{position:absolute;top:10px;left:10px;background:#43a047;color:#fff;font-size:10px;font-weight:800;letter-spacing:.5px;padding:3px 9px;border-radius:20px}.gallery-name{font-size:12px;font-weight:600;color:var(--text-heading);margin:8px 8px 2px;line-height:1.25}.gallery-price{font-family:Playfair Display,serif;font-size:13.5px;font-weight:700;color:var(--accent)}.detail-shell{flex:1;display:flex;flex-direction:column;min-height:100svh;background:var(--bg);overflow-y:auto;-webkit-overflow-scrolling:touch;transition:background .5s var(--ease-apple);scroll-behavior:smooth}.detail-top-bar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:transparent}.detail-restaurant-name{font-family:Playfair Display,serif;font-size:15px;font-weight:700;color:var(--accent);letter-spacing:2px}.icon-circle-btn{width:36px;height:36px;border-radius:50%;background:#0000000f;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-heading);font-size:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000014;transition:transform .2s var(--ease-spring-soft),background .3s;border:1px solid rgba(0,0,0,.05);will-change:transform}[data-theme=dark] .icon-circle-btn{background:#ffffff38;border-color:#ffffff26;color:#fff}.icon-circle-btn:active{transform:scale(.86);transition-duration:.08s}.nav-arrow{position:fixed;top:50%;transform:translateY(-50%);z-index:20;width:32px;height:32px;border-radius:50%;background:#ffffffbf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--text-heading);font-size:13px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #00000026;transition:all .25s var(--ease-standard);max-width:calc(50% - var(--max-w)/2 + 12px)}.nav-prev{left:12px}.nav-next{right:12px}.nav-arrow:active{transform:translateY(-50%) scale(.85);transition-duration:.08s}.nav-arrow.hidden-btn{display:none}@media (min-width: 561px){#detailView{position:relative}.nav-prev{position:absolute;left:12px;top:50%}.nav-next{position:absolute;right:12px;top:50%}}.detail-img-area{flex:0 0 auto;width:100%;padding:16px 0 24px;display:flex;align-items:center;justify-content:center;position:relative;min-height:280px}.detail-new-badge{position:absolute;top:20px;left:50%;transform:translate(-50%) translate(-100px);background:#43a047;color:#fff;font-size:11px;font-weight:800;letter-spacing:.6px;padding:4px 12px;border-radius:20px;display:none}.detail-new-badge.show{display:block}.detail-img{width:400px;height:340px;max-width:90%;object-fit:contain;filter:drop-shadow(0 15px 40px rgba(0,0,0,.3));transition:transform .5s var(--ease-out);border-radius:20px}@keyframes dishEntrance{0%{transform:scale(.7) translateY(30px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.detail-img.animate{animation:dishEntrance .25s var(--ease-spring-soft) both}.detail-info-panel{background:var(--surface);border-radius:var(--radius-sheet) var(--radius-sheet) 0 0;padding:24px 24px 8px;flex:1;box-shadow:0 -4px 24px #00000012}.detail-name{font-family:Playfair Display,serif;font-size:26px;font-weight:700;color:var(--text-heading);text-align:center;line-height:1.25}.detail-price{font-family:Playfair Display,serif;font-size:24px;font-weight:700;color:var(--text-price);text-align:center;margin-top:10px}.detail-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px}.tag-pill{background:var(--tag-bg);color:var(--tag-fg);font-size:11px;font-weight:600;letter-spacing:.5px;padding:5px 13px;border-radius:30px}.detail-actions{background:var(--surface);padding:12px 24px 32px;display:flex;flex-direction:column;align-items:center;gap:8px;border-top:1px solid var(--divider)}.add-to-order-btn{width:100%;background:linear-gradient(135deg,#e91e8c,#c2185b);color:#fff;font-size:15px;font-weight:700;letter-spacing:.8px;padding:18px;border-radius:var(--radius-pill);box-shadow:0 6px 24px #e91e8c59;display:flex;align-items:center;justify-content:center;gap:10px;transition:transform .25s var(--ease-spring-soft),box-shadow .25s var(--ease-standard);will-change:transform}.add-to-order-btn:active{transform:scale(.95);box-shadow:0 2px 8px #e91e8c33;transition-duration:.08s}.add-to-order-btn.wishlisted{background:linear-gradient(135deg,#555,#333);box-shadow:0 6px 24px #00000040}[data-theme=dark] .add-to-order-btn.wishlisted{background:linear-gradient(135deg,#2e2e2e,#1a1a1a)}.bottom-sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:flex;align-items:flex-end;justify-content:center;pointer-events:none}.bottom-sheet.open{pointer-events:auto}.sheet-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000;transition:background .3s var(--ease-out);-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:background .3s,backdrop-filter .3s}.bottom-sheet.open .sheet-overlay{background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sheet-panel{position:relative;z-index:1;width:100%;max-width:var(--max-w);background:var(--surface-sheet);border-radius:var(--radius-sheet) var(--radius-sheet) 0 0;padding:24px 24px 36px;box-shadow:var(--shadow-sheet);transform:translateY(105%);visibility:hidden;transition:transform .25s var(--ease-decelerate),visibility .25s;will-change:transform}.bottom-sheet.open .sheet-panel{transform:translateY(0);visibility:visible}.sheet-title{font-family:Playfair Display,serif;font-size:20px;font-weight:700;color:var(--text-heading);text-align:center;margin-bottom:22px}.cart-title{display:flex;align-items:center;justify-content:center;gap:10px}.qty-row{display:flex;align-items:center;justify-content:center;gap:28px;margin-bottom:28px}.qty-circle{width:50px;height:50px;border-radius:50%;border:2px solid var(--accent);color:var(--accent);font-size:17px;display:flex;align-items:center;justify-content:center;background:transparent;transition:all .18s var(--ease-spring)}.qty-circle:active{background:var(--accent);color:#fff;transform:scale(.9)}.qty-num{font-family:Playfair Display,serif;font-size:36px;font-weight:700;color:var(--text-heading);min-width:30px;text-align:center}.qty-total-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px;padding-bottom:16px;border-bottom:1px solid var(--divider)}.qty-total-label{font-size:14px;font-weight:600;color:var(--text-body);display:flex;flex-direction:column;gap:2px}.qty-excl{font-size:11px;font-weight:400;color:var(--text-muted)}.qty-total-price{font-family:Playfair Display,serif;font-size:22px;font-weight:700;color:var(--text-price)}.wishlist-item-img{width:100px;height:85px;border-radius:12px;object-fit:contain;flex-shrink:0;background:var(--surface2);padding:4px}.wishlist-item-info{flex:1;min-width:0}.wishlist-item-name{font-size:14px;font-weight:600;color:var(--text-heading);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wishlist-item-price{font-family:Playfair Display,serif;font-size:15px;font-weight:700;color:var(--text-price);margin-top:3px}.wishlist-remove-btn{color:#e53935;background:#e539351a;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;transition:transform .1s var(--ease-spring-soft),background .2s;flex-shrink:0}.wishlist-remove-btn:active{transform:scale(.8);background:#e5393533}.wishlist-empty-msg{text-align:center;padding:36px 0;color:var(--text-muted);font-size:14px}.wishlist-empty-msg i{font-size:48px;display:block;margin-bottom:14px;color:#e91e8c;opacity:.35}.confirm-add-btn{width:100%;background:linear-gradient(135deg,#e91e8c,#c2185b);color:#fff;font-size:15px;font-weight:700;letter-spacing:.8px;padding:18px;border-radius:var(--radius-pill);box-shadow:0 6px 20px #e91e8c59;display:flex;align-items:center;justify-content:center;gap:10px;transition:transform .09s var(--ease-spring)}.confirm-add-btn:active{transform:scale(.97)}.cart-panel{max-height:90svh;display:flex;flex-direction:column;gap:0;padding-bottom:0}.cart-items-list{flex:1;overflow-y:auto;margin-bottom:16px;scrollbar-width:thin}.cart-row{display:flex;align-items:center;padding:14px 0;gap:16px;border-bottom:1px solid var(--divider)}.cart-row:last-child{border-bottom:none}.cart-row-left{flex:1}.cart-item-label{font-size:14.5px;font-weight:600;color:var(--text-heading)}.cart-item-label span{color:var(--text-muted);font-weight:400}.cart-row-right{display:flex;align-items:center;gap:14px}.cart-item-price{font-family:Playfair Display,serif;font-size:16px;font-weight:700;color:var(--text-price);min-width:60px;text-align:right}.cart-remove-btn{color:#e53935;font-size:14px;transition:transform .07s var(--ease-spring)}.cart-remove-btn:active{transform:scale(.8)}.cart-empty-msg{text-align:center;padding:30px 0;color:var(--text-muted);font-size:14px}.cart-empty-msg i{font-size:40px;display:block;margin-bottom:12px;color:#c8e6c9}.table-input{width:100%;border:none;border-bottom:1.5px solid #ddd;outline:none;background:transparent;font-size:14px;color:var(--text-body);padding:14px 0;margin-bottom:4px;transition:border-color .2s}.table-input::placeholder{color:var(--text-muted)}.table-input:focus{border-color:var(--accent)}.cart-total-row{border-bottom:none;margin-bottom:18px;padding-bottom:0}.place-order-btn{width:calc(100% - 48px);background:linear-gradient(135deg,#3d6b3f,#2d5230);color:#fff;font-size:15px;font-weight:700;letter-spacing:1px;padding:18px;border-radius:var(--radius-pill);box-shadow:0 6px 20px #2d523066;transition:transform .09s var(--ease-spring);margin:0 24px 12px;align-self:center}.place-order-btn:active{transform:scale(.97)}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%) translateY(80px);opacity:0;pointer-events:none;z-index:500;background:#1e1e1ef2;color:#fff;font-size:13.5px;font-weight:500;padding:11px 24px;border-radius:30px;white-space:nowrap;box-shadow:0 10px 40px #0000004d;transition:transform .5s var(--ease-spring-soft),opacity .4s ease-out;will-change:transform,opacity}.toast.show{transform:translate(-50%) translateY(0) scale(1.05);opacity:1}@media (min-width: 561px){body{background:var(--bg-outer)}.view{box-shadow:0 0 80px #0003}:root{--max-w: 640px}}@media (min-width: 900px){:root{--max-w: 720px}.cat-card{width:58px;min-height:58px}.detail-img{width:320px;height:320px}}@media (min-width: 1200px){:root{--max-w: 820px}.hero-header{padding:8px 40px 24px}.restaurant-name{font-size:36px}}.top-admin-btn{position:relative;width:28px;height:28px;border-radius:50%;background:#ffffffbf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.9);color:var(--text-heading);font-size:13px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #0000001f;transition:transform .06s var(--ease-spring-soft),background .15s,color .15s;text-decoration:none}.top-admin-btn:active{transform:scale(.85);transition-duration:.04s}[data-theme=dark] .top-admin-btn{background:#1e261ed9;border-color:#ffffff1f;color:var(--text-heading)}.menu-footer{text-align:center;padding:30px 18px 45px;background:transparent;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:20px}.footer-copy{font-size:11px;color:var(--text-muted)}.footer-admin-btn{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1.5px solid var(--border);color:var(--text-heading);padding:6px 16px;font-size:11px;font-weight:600;border-radius:var(--radius-pill);text-decoration:none;box-shadow:var(--shadow-card);transition:all .2s var(--ease-standard)}.footer-admin-btn:hover{background:var(--border);transform:translateY(-1px)}.footer-admin-btn:active{transform:translateY(0) scale(.96)}.footer-admin-btn i{font-size:10px;color:var(--accent)}.menu-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px;color:var(--text-heading)}.loading-spinner{font-size:42px;color:var(--accent)}.menu-loading p{font-size:14px;font-weight:500;color:var(--text-muted);letter-spacing:.5px}.cat-card-loading{color:var(--text-muted);font-size:12px;font-weight:500;padding:12px 24px;opacity:.6}.dish-row.out-of-stock .list-thumb,.dish-gallery-card.out-of-stock .gallery-img{filter:grayscale(.8) opacity(.5);transition:filter .3s}.dish-row.out-of-stock .list-name,.dish-row.out-of-stock .list-price,.dish-gallery-card.out-of-stock .gallery-name,.dish-gallery-card.out-of-stock .gallery-price{opacity:.65}.list-thumb-wrap,.gallery-img-wrap{position:relative}.list-out-of-stock-badge{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;color:#ff5252;font-size:8px;font-weight:800;display:flex;align-items:center;justify-content:center;border-radius:12px;letter-spacing:.5px;text-transform:uppercase}.gallery-out-of-stock-badge{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;color:#ff5252;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center;border-radius:12px;letter-spacing:.5px;text-transform:uppercase}.add-to-order-btn.disabled-btn{background:linear-gradient(135deg,#757575,#424242)!important;box-shadow:none!important;cursor:not-allowed;opacity:.8;pointer-events:none}body{background:var(--bg-outer);display:block;min-height:100vh}.admin-shell{width:100%;max-width:1200px;margin:0 auto;padding:20px 16px;min-height:100vh;display:flex;flex-direction:column;justify-content:center}.admin-view{display:none;width:100%;flex-direction:column;animation:pageSlideIn .3s var(--ease-decelerate) both}.admin-view.active{display:flex}.login-card{max-width:400px;width:100%;margin:0 auto;background:var(--surface);border-radius:var(--radius-card);padding:40px 30px;box-shadow:var(--shadow-card);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.brand-header{text-align:center;margin-bottom:30px}.brand-logo{font-size:40px;color:var(--accent);margin-bottom:12px;filter:drop-shadow(0 4px 8px rgba(74,142,79,.2))}.brand-title{font-family:Playfair Display,serif;font-size:24px;font-weight:700;color:var(--text-heading);letter-spacing:2px;margin-bottom:4px}.brand-subtitle{font-size:13px;color:var(--text-muted)}.input-group{margin-bottom:20px;display:flex;flex-direction:column;gap:8px}.input-group label{font-size:12px;font-weight:600;color:var(--text-heading);letter-spacing:.5px}.input-group input,.inline-input-group input,.form-inputs-row input{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:12px 16px;font-size:14px;color:var(--text-body);outline:none;transition:border-color .2s var(--ease-standard),box-shadow .2s var(--ease-standard);width:100%}.input-group input:focus,.inline-input-group input:focus,.form-inputs-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 15%,transparent)}.error-banner{background:#8d1c1c26;color:#ff4d4d;border:1.5px solid rgba(141,28,28,.3);padding:10px 14px;border-radius:12px;font-size:12px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.error-banner.hidden{display:none}.admin-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-pill);font-size:13px;font-weight:700;transition:transform .1s var(--ease-spring-soft),background .2s var(--ease-standard),color .2s;cursor:pointer;text-decoration:none}.admin-btn:active{transform:scale(.95)}.primary-btn{background:var(--accent-btn);color:#fff;box-shadow:0 4px 15px #4a8e4f4d}.primary-btn:hover{filter:brightness(1.05)}.secondary-btn{background:var(--surface2);color:var(--text-body);border:1px solid var(--border)}.secondary-btn:hover{background:var(--border)}.text-danger-btn{background:transparent;color:#ff4d4d;padding:6px 12px;font-size:12px}.text-danger-btn:hover{background:#ff4d4d1a}.admin-btn-icon{width:42px;height:42px;border-radius:12px;background:var(--accent-btn);color:#fff;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;font-size:16px;transition:transform .1s}.admin-btn-icon:active{transform:scale(.9)}.admin-header{display:flex;justify-content:space-between;align-items:center;background:var(--surface);padding:16px 24px;border-radius:var(--radius-card);margin-bottom:24px;box-shadow:var(--shadow-card);border:1px solid var(--border);width:100%;box-sizing:border-box}.header-title{font-family:Playfair Display,serif;font-size:20px;font-weight:700;color:var(--text-heading);letter-spacing:1px}.header-badge{font-size:10px;font-weight:700;color:var(--accent);background:color-mix(in srgb,var(--accent) 15%,transparent);padding:3px 8px;border-radius:8px;margin-left:8px}.header-right{display:flex;align-items:center;gap:12px}.header-action-btn{padding:8px 16px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;color:var(--text-body);background:var(--surface2);border:1px solid var(--border);text-decoration:none;display:flex;align-items:center;gap:6px;transition:all .2s;cursor:pointer}.header-action-btn:hover{background:var(--border)}.header-action-btn.danger{color:#ff4d4d;background:#ff4d4d0d;border-color:#ff4d4d26}.header-action-btn.danger:hover{background:#ff4d4d1f}.header-action-btn.warning{color:#f59e0b;background:#f59e0b0d;border-color:#f59e0b26}.header-action-btn.warning:hover{background:#f59e0b1f}.dashboard-grid{display:grid;grid-template-columns:280px 1fr;grid-template-rows:auto auto;gap:24px;align-items:start}.admin-card{background:var(--surface);border-radius:var(--radius-card);padding:24px;box-shadow:var(--shadow-card);border:1px solid var(--border);position:relative}.card-title{font-size:15px;font-weight:700;color:var(--text-heading);margin-bottom:20px;display:flex;align-items:center;gap:8px;border-bottom:1.5px solid var(--divider);padding-bottom:10px}.category-sidebar{grid-row:1 / 3;display:flex;flex-direction:column;height:100%;max-height:700px}.categories-list-wrap{flex:1;overflow-y:auto;margin-bottom:16px;scrollbar-width:thin}.admin-list{display:flex;flex-direction:column;gap:6px}.admin-list-item{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:12px;color:var(--text-body);font-size:13.5px;font-weight:500;cursor:pointer;background:var(--surface2);border:1px solid transparent;transition:all .2s}.admin-list-item:hover{background:var(--divider)}.admin-list-item.active{background:var(--accent);color:#fff;font-weight:600}.admin-list-item.active .badge-count{background:#ffffff40;color:#fff}.badge-count{font-size:10px;background:var(--divider);color:var(--text-muted);padding:2px 6px;border-radius:6px}.sidebar-form{margin-top:auto}.inline-input-group{display:flex;gap:8px}.inline-input-group input{flex:1}.dishes-panel{grid-column:2 / 3}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.panel-header .card-title{border:none;padding:0;margin:0}.dishes-table-wrap{overflow-x:auto;border-radius:14px;border:1px solid var(--border);background:var(--surface2);margin-bottom:24px}.dishes-table{width:100%;border-collapse:collapse;text-align:left;font-size:13px}.dishes-table th,.dishes-table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.dishes-table th{font-weight:600;color:var(--text-heading);background:color-mix(in srgb,var(--surface) 50%,var(--surface2))}.dishes-table tr:last-child td{border-bottom:none}.actions-col{text-align:right;width:120px}.table-thumb-wrap{position:relative;width:54px;height:54px;border-radius:8px;overflow:hidden;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center}.table-thumb{width:100%;height:100%;object-fit:contain}.table-photo-cell{position:relative;width:80px}.change-photo-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;opacity:0;transition:opacity .2s;border-radius:8px}.table-thumb-wrap:hover .change-photo-overlay{opacity:1}.table-dish-info{display:flex;flex-direction:column;gap:4px}.table-input-name{font-weight:600;font-size:13.5px;border:1px solid transparent!important;background:transparent!important;padding:4px!important;border-radius:6px!important}.table-input-name:focus{border-color:var(--border)!important;background:var(--surface)!important}.table-input-price{font-weight:600;width:80px!important;border:1px solid transparent!important;background:transparent!important;padding:4px!important;border-radius:6px!important}.table-input-price:focus{border-color:var(--border)!important;background:var(--surface)!important}.row-action-btn{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:background .15s,color .15s}.save-row-btn{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent);margin-right:6px}.save-row-btn:hover{background:var(--accent);color:#fff}.delete-row-btn{background:#ff4d4d14;color:#ff4d4d}.delete-row-btn:hover{background:#ff4d4d;color:#fff}.switch-container{position:relative;display:inline-block;width:34px;height:20px}.switch-container input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--divider);transition:.2s;border:1px solid var(--border)}.slider:before{position:absolute;content:"";height:12px;width:12px;left:3px;bottom:3px;background-color:var(--text-muted);transition:.2s}input:checked+.slider{background-color:var(--accent);border-color:var(--accent)}input:checked+.slider:before{transform:translate(14px);background-color:#fff}.slider.round{border-radius:20px}.slider.round:before{border-radius:50%}.toggle-label{font-size:11px;font-weight:600;color:var(--text-body)}.add-dish-box{background:var(--surface2);border-radius:16px;padding:20px;border:1px solid var(--border)}.sub-title{font-size:13px;font-weight:700;color:var(--text-heading);margin-bottom:16px}.add-dish-form{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.upload-field{display:flex;align-items:center;gap:12px}.image-preview-box{width:50px;height:50px;border-radius:10px;background:var(--surface);border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:20px;overflow:hidden}.image-preview-box img{width:100%;height:100%;object-fit:contain}.hidden-file-input{display:none}.form-inputs-row{flex:1;display:flex;gap:12px;align-items:center;flex-wrap:wrap;width:100%}.form-inputs-row .input-field{flex:1;min-width:150px}.form-inputs-row .input-field.shrink{flex:0 0 100px;min-width:80px}.form-inputs-row .input-field.toggle-field{display:flex;align-items:center;gap:8px;flex:0 0 auto}.add-btn{padding:10px 20px}.qr-panel{grid-column:2 / 3}.qr-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:16px}.qr-text{font-size:13px;color:var(--text-body)}.qr-code-box{background:#fff;padding:14px;border-radius:16px;box-shadow:0 4px 20px #0000001a;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border)}.qr-code-box img{width:160px;height:160px}.qr-url-box{display:flex;align-items:center;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:8px 12px;width:100%;max-width:500px;gap:10px}.qr-url-label{font-size:11px;font-weight:700;color:var(--text-muted);white-space:nowrap}.qr-url-box input{flex:1;border:none;background:transparent;font-size:12px;color:var(--text-body);outline:none;font-family:monospace}@media (max-width: 900px){.dashboard-grid{grid-template-columns:1fr}.category-sidebar{grid-row:auto;height:auto;max-height:400px}.dishes-panel,.qr-panel{grid-column:1 / 2}.admin-header{flex-direction:row;justify-content:space-between;align-items:center;padding:12px 16px;gap:12px;width:100%;box-sizing:border-box}.header-left{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.header-badge{margin-left:0}.header-right{display:flex;flex-direction:row;align-items:center;gap:8px;justify-content:flex-end;flex-wrap:nowrap}}@media (max-width: 600px){.admin-shell{padding:12px 8px}.admin-header{flex-direction:column;align-items:center;justify-content:center;padding:16px 12px;gap:12px}.header-left{display:flex;flex-direction:column;align-items:center;gap:4px}.header-title{font-size:14px;letter-spacing:.5px}.header-badge{font-size:8.5px;padding:1.5px 6px;margin-left:0}.header-right{justify-content:center;flex-wrap:wrap;gap:8px;width:100%}.header-action-btn{padding:6px 12px;font-size:9.5px;gap:3px}.dishes-table th,.dishes-table td{padding:8px 6px}.table-photo-cell{width:50px}.table-thumb-wrap{width:40px;height:40px}.table-input-name{font-size:12px!important;padding:4px 6px!important}.table-input-price{width:55px!important;padding:4px 6px!important}.actions-col{text-align:center;padding:8px 2px;width:auto}.row-action-btn{margin:4px 2px}.save-row-btn{margin-right:0}.dishes-table td>div{gap:4px!important}.switch-container{flex-shrink:0}.toggle-label{white-space:nowrap}.form-inputs-row{flex-direction:column;align-items:stretch}.form-inputs-row .input-field,.form-inputs-row .input-field.shrink{flex:1 0 auto;width:100%}.add-dish-form{flex-direction:column;align-items:stretch}.upload-field{justify-content:space-between}.add-btn{width:100%}}
