@import"https://cdn.jsdelivr.net/npm/@splidejs/splide@4.1.4/dist/css/splide.min.css";.menu-app{min-height:100vh;padding-bottom:110px;--bottom-nav-width: min(420px, 92vw);--bottom-nav-height: 76px}.top-bar{position:sticky;top:0;z-index:20;backdrop-filter:blur(18px);background:#f5f8ffe6;border-bottom:1px solid rgba(15,42,77,.08)}.top-bar-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:16px 0;gap:12px}.top-left{display:flex;flex-direction:column;gap:4px;color:#4b5f8a;font-size:.75rem}.status-pill{background:#1f57b41a;color:var(--brand-primary);padding:4px 10px;border-radius:999px;font-weight:600;font-size:.7rem;align-self:flex-start}.top-logo img{height:32px;display:block}.logo-text{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:1.1rem;letter-spacing:.2em}.top-actions{display:flex;justify-content:flex-end}.icon-button{width:42px;height:42px;border-radius:14px;border:1px solid rgba(31,87,180,.15);background:#fff;display:grid;place-items:center;box-shadow:0 12px 24px #0f2a4d14}.hero{padding:30px 0 10px;position:relative}.hero-splide{position:relative;padding:0;border-radius:24px;background:transparent;box-shadow:none;overflow:hidden;border:0!important;outline:0!important}.hero-splide-skeleton{position:absolute;inset:0;border-radius:22px;overflow:hidden;pointer-events:none;opacity:1;z-index:2;background:linear-gradient(135deg,#d9e6ff,#edf3ff,#d3e2ff);transition:opacity .24s ease}.hero-skeleton-shine{position:absolute;inset:0;background:linear-gradient(105deg,transparent 0%,transparent 36%,rgba(255,255,255,.86) 50%,transparent 64%,transparent 100%);transform:translate(-130%);animation:heroShimmer 1.4s linear infinite}.hero-splide .splide__track{border-radius:22px;overflow:hidden;box-shadow:none;transition:opacity .24s ease;opacity:0;border:0!important;outline:0!important}.hero-splide[data-ready=false] .hero-splide-skeleton{opacity:1}.hero-splide[data-ready=false] .splide__track,.hero-splide[data-ready=true] .hero-splide-skeleton{opacity:0}.hero-splide[data-ready=true] .splide__track{opacity:1}.hero-splide .splide__slide{height:clamp(180px,32vw,320px);position:relative}.hero-splide .splide__slide:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,#102c602e,#102c600d,#102c6000 60%);pointer-events:none}.hero-splide .splide__slide img{width:100%;height:100%;object-fit:cover;display:block}.hero-splide .splide__pagination{bottom:14px}.hero-splide .splide__pagination__page{background:#ffffffc7;border:1px solid rgba(16,44,96,.12);opacity:1;width:9px;height:9px;margin:0 4px}.hero-splide .splide__pagination__page.is-active{background:var(--brand-primary);transform:scale(1.28);border-color:#ffffffd9;box-shadow:0 4px 10px #1f57b457}@media(max-width:640px){.hero-splide{border-radius:24px}.hero-splide-skeleton{inset:0;border-radius:18px}.hero-splide .splide__track{border-radius:18px}}@keyframes heroShimmer{to{transform:translate(130%)}}.menu-section{padding:32px 0 120px;position:relative}.menu-section:before{content:"";position:absolute;inset:12px 0 auto;height:220px;border-radius:0;background:transparent;z-index:0}.menu-section>*{position:relative;z-index:1}.section-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.section-header h2{font-size:1.6rem;margin-bottom:4px}.section-actions{display:flex;gap:12px;flex-wrap:wrap}.ghost-button,.solid-button{border-radius:999px;padding:10px 18px;font-weight:600;border:none;display:inline-flex;align-items:center;gap:8px}.ghost-button{background:#fff;color:var(--brand-primary);border:1px solid rgba(31,87,180,.2)}.solid-button{background:var(--brand-primary);color:#fff;box-shadow:0 16px 26px #1f57b433}.menu-loading{display:grid;gap:22px;margin-top:24px}.skeleton-block{display:grid;gap:14px}.skeleton-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.skeleton-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.skeleton-card{border-radius:18px;border:1px solid rgba(16,44,96,.08);background:#fff;box-shadow:0 14px 24px #102c600f;padding:10px;display:grid;gap:10px}.skeleton-media,.skeleton-line,.skeleton-pill{display:block;background:linear-gradient(100deg,#e9effff2 20%,#fff,#e9effff2 70%);background-size:220% 100%;animation:skeleton-wave 1.35s ease-in-out infinite}.skeleton-media{width:100%;aspect-ratio:16 / 10;border-radius:12px}.skeleton-line{height:12px;border-radius:8px}.skeleton-line.title{width:min(280px,48vw);height:20px}.skeleton-line.item-title{width:78%}.skeleton-line.item-desc{width:58%}.skeleton-pill{width:72px;height:24px;border-radius:999px}@keyframes skeleton-wave{0%{background-position:0% 50%}to{background-position:100% 50%}}@media(max-width:640px){.skeleton-grid{gap:12px}.skeleton-card{border-radius:16px;padding:9px;gap:8px}.skeleton-line.title{width:min(210px,56vw);height:18px}.skeleton-pill{width:58px;height:20px}}.menu-grid{display:flex;flex-direction:column;gap:24px;margin-top:24px}.menu-block{background:transparent;border-radius:0;padding:0 0 8px;border:none;box-shadow:none;margin-bottom:18px}.menu-block-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;padding-bottom:10px;border-bottom:none}.menu-block-header h3{margin:0;font-size:clamp(1.35rem,2.1vw,1.8rem);font-weight:700}.menu-block-header p{margin:0;color:#6b7a9c;font-size:.85rem}.count-pill{background:#1f57b414;color:var(--brand-primary);padding:6px 12px;border-radius:999px;font-size:.7rem;font-weight:600}.menu-items-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.menu-item-link{text-decoration:none;color:inherit;display:block;cursor:pointer;position:relative;z-index:1}.menu-item-link:focus-visible{outline:2px solid rgba(31,87,180,.35);outline-offset:3px;border-radius:20px}.menu-item{background:linear-gradient(180deg,#fff,#f6f8ff);border-radius:18px;padding:14px 16px;border:1px solid rgba(16,44,96,.06);position:relative}.menu-item-media{width:100%;height:140px;border-radius:14px;overflow:hidden;margin-bottom:12px;background:radial-gradient(circle at 20% 20%,#f7f9ff,#e8eef9 55%,#e1e8f6);display:block;border:1px solid rgba(16,44,96,.08);position:relative}.menu-item-media img{display:block;width:100%;height:100%;object-fit:cover;object-position:50% 50%}.menu-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.menu-item h4{margin:0;font-size:.98rem}.menu-item span{font-size:.78rem;color:#6b7a9c}.menu-item p{font-size:.8rem;margin:8px 0 4px;color:#3e4b6a}.menu-item-controls{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:12px;width:100%}.menu-item-controls .add-btn{width:54px;height:54px;border-radius:18px;border:none;background:var(--brand-primary);color:#fff;font-weight:700;font-size:1.9rem;display:grid;place-items:center;box-shadow:0 16px 28px #1f57b440;transition:transform .2s ease,box-shadow .2s ease}.menu-item-controls .add-btn .add-icon{font-size:inherit;color:inherit;line-height:1}.menu-item-controls.has-qty .add-btn{background:#163e86;box-shadow:0 18px 30px #1f57b44d}.menu-item-controls .add-btn:active{transform:scale(.96);box-shadow:0 10px 18px #1f57b440}.menu-item small{font-size:.72rem;color:#9aa7c2}.allergen-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.allergen-stack .allergen-chip{margin-left:-6px}.allergen-stack .allergen-chip:first-child{margin-left:0}.allergen-chip{display:inline-flex;align-items:center;gap:3px;background:#f0f4ff;color:#1f2f4a;height:20px;padding:0 8px;border-radius:999px;font-size:.56rem;line-height:1;font-weight:600;border:1px solid rgba(16,44,96,.12);box-shadow:0 4px 10px #0f2a4d0f;white-space:nowrap}.allergen-icon{width:10px;height:10px;display:grid;place-items:center;font-size:.62rem;line-height:1;overflow:hidden}.error-card{padding:20px;border-radius:16px;background:#fff4f4;color:#c0392b;border:1px solid rgba(192,57,43,.2)}html[data-product-modal=open],html[data-product-modal=open] body{overflow:hidden}.product-overlay{position:fixed;inset:0;z-index:24;background:#0a122080;backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity .2s ease;display:flex;justify-content:center;align-items:flex-end;padding:24px 16px calc(var(--bottom-nav-height) + 32px)}.product-overlay.is-open{opacity:1;pointer-events:auto}.product-sheet{width:min(520px,100%);height:min(760px,calc(100dvh - var(--bottom-nav-height) - 56px));max-height:calc(100dvh - var(--bottom-nav-height) - 56px);border-radius:24px;background:#fff;box-shadow:0 28px 60px #0f2a4d47;border:1px solid rgba(16,44,96,.08);position:relative;overflow:hidden;display:flex;flex-direction:column}.product-close{position:absolute;top:14px;right:14px;z-index:4;background:#fffffff0;backdrop-filter:blur(8px)}.product-modal-banner{width:100%;flex:0 0 clamp(210px,34vh,320px);overflow:hidden;border-radius:22px 22px 0 0;background:linear-gradient(135deg,var(--brand-primary),var(--brand-secondary))}.product-modal-banner img{width:100%;height:100%;display:block;object-fit:cover;object-position:center}.product-modal-card{flex:1 1 auto;min-height:0;overflow-y:auto;padding:18px 20px 24px;display:grid;gap:12px;background:linear-gradient(180deg,#fff,#f8faff)}.product-modal-card::-webkit-scrollbar{width:8px}.product-modal-card::-webkit-scrollbar-track{background:transparent}.product-modal-card::-webkit-scrollbar-thumb{background:#1f57b43d;border-radius:999px}.product-modal-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.product-modal-title-row h2{margin:0;font-size:clamp(1.35rem,2.4vw,2rem)}.product-modal-price{background:var(--brand-primary);color:#fff;border-radius:999px;padding:6px 12px;font-size:.78rem;font-weight:700;white-space:nowrap}.product-modal-meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.product-modal-description{margin:0;color:#2f3b55;font-size:.95rem;line-height:1.42}.product-modal-allergens{display:none;gap:8px;flex-wrap:wrap;margin-top:2px}.product-modal-allergens.has-items{display:flex}.product-modal-order{margin-top:8px;display:flex;justify-content:flex-end}.product-modal-order .add-btn{width:52px;height:52px;border-radius:18px;border:none;background:var(--brand-primary);color:#fff;font-size:1.6rem;font-weight:700;display:grid;place-items:center;box-shadow:0 16px 26px #1f57b447}.product-modal-order .add-btn .add-icon{line-height:1}@media(max-width:768px){.product-sheet{height:min(700px,calc(100dvh - var(--bottom-nav-height) - 44px));max-height:calc(100dvh - var(--bottom-nav-height) - 44px);border-radius:22px}.product-modal-banner{flex-basis:clamp(180px,28vh,250px);border-radius:20px 20px 0 0}.product-modal-card{padding:16px 16px 20px;gap:10px}}.bottom-nav{position:fixed;left:50%;bottom:16px;transform:translate(-50%);width:var(--bottom-nav-width);height:var(--bottom-nav-height);display:grid;grid-template-columns:repeat(5,1fr);align-items:center;gap:6px;padding:12px 14px;border-radius:28px;background:#fffffff2;box-shadow:0 24px 50px #0f2a4d33;border:1px solid rgba(16,44,96,.08);z-index:80}.category-overlay{position:fixed;inset:0;background:#0a122066;backdrop-filter:blur(10px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:25}.category-overlay.is-open{opacity:1;pointer-events:auto}.category-sheet{width:var(--bottom-nav-width);background:#fff;border-radius:28px 28px 24px 24px;padding:20px;box-shadow:0 24px 50px #0f2a4d40;border:1px solid rgba(16,44,96,.08);transform:translateY(30px);transition:transform .25s ease;margin-bottom:calc(var(--bottom-nav-height) + 38px)}.category-overlay.is-open .category-sheet{transform:translateY(0)}.category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.category-header p{margin:0;font-size:.75rem;color:#6b7a9c}.category-header h4{margin:0;font-size:1.1rem}.category-list{display:grid;gap:10px;margin-top:12px}.category-chip{border:1px solid rgba(31,87,180,.12);background:linear-gradient(180deg,#fff,#f6f8ff);border-radius:16px;padding:12px 14px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-weight:600;color:#1f2f4a;text-align:left;box-shadow:0 12px 22px #0f2a4d14}.category-chip small{font-weight:500;font-size:.7rem;color:#6b7a9c}.nav-item{background:transparent;border:none;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.65rem;color:#405070}.nav-center{background:transparent;border:none;display:grid;place-items:center}.nav-center-inner{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--brand-primary),var(--brand-secondary));color:#f5f7ff;display:grid;place-items:center;box-shadow:0 18px 30px #0f2a4d4d;transform:translateY(-28px);border:6px solid #edf1f8}@media(min-width:992px){.bottom-nav{display:none}}@media(max-width:768px){.section-actions{width:100%}.menu-app{padding-bottom:140px}.menu-items-grid{grid-template-columns:1fr}.menu-item{display:grid;grid-template-columns:112px minmax(0,1fr);grid-template-areas:"media header" "media description" "media controls";gap:10px 12px;padding:12px;align-items:start}.menu-item-media{grid-area:media;width:112px;height:112px;margin-bottom:0;border-radius:14px;aspect-ratio:1 / 1}.menu-item-header{grid-area:header;gap:10px;min-width:0}.menu-item h4{font-size:1rem;line-height:1.2;margin:0}.menu-item-header strong{font-size:.92rem;white-space:nowrap}.menu-item p{grid-area:description;margin:0;font-size:.8rem;line-height:1.35}.menu-item-controls{grid-area:controls;margin-top:2px;justify-content:flex-end}.menu-item-controls .add-btn{width:48px;height:48px;border-radius:15px;font-size:1.7rem}}@media(max-width:420px){.menu-item{grid-template-columns:98px minmax(0,1fr);padding:11px;gap:8px 10px}.menu-item-media{width:98px;height:98px}.menu-item h4{font-size:.94rem}.menu-item p{font-size:.76rem}}
