*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #faf7f2;--bg-secondary: #f3ece2;--bg-card: #ffffff;--bg-card-hover: #fdf9f4;--bg-glass: rgba(250, 247, 242, .88);--accent: #8b5e3c;--accent-light: #a97c5a;--accent-dark: #6d452a;--accent-glow: rgba(139, 94, 60, .08);--text-primary: #2c1b0e;--text-secondary: #6b5744;--text-muted: #9a8a78;--text-price: #8b5e3c;--border: rgba(139, 94, 60, .1);--border-active: rgba(139, 94, 60, .25);--header-height: 200px;--nav-height: 56px;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;font-family:Inter,system-ui,-apple-system,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-height) + 16px)}body{background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;min-height:100dvh;overflow-x:hidden}#root{min-height:100vh;min-height:100dvh}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--accent-light);border-radius:10px}.menu-app{width:100%;max-width:480px;margin:0 auto;min-height:100vh;min-height:100dvh;position:relative}.menu-header{position:relative;width:100%;height:var(--header-height);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;overflow:hidden;background:linear-gradient(180deg,#efe6d8 0%,#f3ece2 50%,var(--bg-primary) 100%)}.menu-header:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(139,94,60,.06) 0%,transparent 70%);pointer-events:none}.header-logo{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--accent-light);box-shadow:0 4px 20px #8b5e3c1f;position:relative;z-index:1;animation:logoFloat 3s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.header-title{font-family:Playfair Display,serif;font-size:1.75rem;font-weight:700;color:var(--text-primary);letter-spacing:.04em;position:relative;z-index:1}.header-subtitle{font-size:.8rem;font-weight:400;color:var(--text-muted);letter-spacing:.15em;text-transform:uppercase;position:relative;z-index:1}.category-nav{position:sticky;top:0;z-index:100;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:12px 0;transition:box-shadow .3s ease}.category-nav.scrolled{box-shadow:0 2px 20px #8b5e3c14}.category-nav-inner{display:flex;gap:8px;overflow-x:auto;padding:0 16px;scrollbar-width:none;-ms-overflow-style:none}.category-nav-inner::-webkit-scrollbar{display:none}.category-pill{flex-shrink:0;padding:8px 18px;border-radius:100px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;user-select:none;-webkit-user-select:none}.category-pill:active{transform:scale(.95)}.category-pill.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600;box-shadow:0 2px 12px #8b5e3c33}.menu-body{padding:0 16px 80px}.menu-section{padding-top:28px}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.section-line{flex:1;height:1px;background:linear-gradient(90deg,var(--border-active),transparent)}.section-title{font-family:Playfair Display,serif;font-size:1.25rem;font-weight:600;color:var(--accent-dark);white-space:nowrap}.section-count{font-size:.7rem;color:var(--text-muted);font-weight:500;white-space:nowrap}.product-list{display:flex;flex-direction:column;gap:12px}.product-card{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:16px;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border);box-shadow:0 1px 4px #00000008;transition:all .3s cubic-bezier(.4,0,.2,1);animation:cardFadeIn .4s ease-out both}.product-card:active{transform:scale(.985);background:var(--bg-card-hover)}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.product-info{flex:1;min-width:0}.product-name{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:4px;line-height:1.3}.product-description{font-size:.78rem;color:var(--text-muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-price{flex-shrink:0;font-size:1rem;font-weight:700;color:var(--text-price);padding:6px 14px;background:var(--accent-glow);border-radius:100px;border:1px solid rgba(139,94,60,.08);white-space:nowrap}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;gap:24px;background:var(--bg-primary)}.loading-spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:.85rem;color:var(--text-muted);font-weight:500;letter-spacing:.05em}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px;padding:32px;text-align:center}.error-icon{font-size:2.5rem}.error-text{font-size:.9rem;color:var(--text-muted);line-height:1.6}.error-retry{padding:10px 28px;border-radius:100px;border:1px solid var(--accent);background:transparent;color:var(--accent);font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px}.error-retry:active{background:var(--accent);color:#fff}.empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:12px;text-align:center;padding:32px}.empty-icon{font-size:2.5rem}.empty-text{font-size:.9rem;color:var(--text-muted)}.menu-footer{text-align:center;padding:32px 16px 24px;border-top:1px solid var(--border);margin-top:16px}.footer-text{font-size:.7rem;color:var(--text-muted);letter-spacing:.1em}@media(min-width:481px){.menu-app{max-width:560px}.header-logo{width:84px;height:84px}.header-title{font-size:2rem}.product-card{padding:20px}.product-name{font-size:1rem}.product-price{font-size:1.05rem}}@media(min-width:769px){.menu-app{max-width:640px}:root{--header-height: 240px}.product-card:hover{background:var(--bg-card-hover);border-color:var(--border-active);transform:translateY(-1px);box-shadow:0 4px 20px #0000000f}.category-pill:hover:not(.active){background:#8b5e3c0d;color:var(--accent-dark);border-color:var(--border-active)}.error-retry:hover{background:var(--accent);color:#fff}}
