@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Playfair+Display:ital,wght@0,400;0,700;1,400&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-tertiary:#1a1a2e;--bg-card:#161623d9;--bg-glass:#ffffff0a;--bg-glass-hover:#ffffff14;--text-primary:#f0f0f5;--text-secondary:#a0a0b8;--text-muted:#6a6a82;--accent-primary:#e8b84b;--accent-secondary:#d4943a;--accent-gradient:linear-gradient(135deg, #e8b84b 0%, #d4943a 50%, #c97b2e 100%);--accent-glow:#e8b84b40;--border-subtle:#ffffff0f;--border-accent:#e8b84b4d;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 8px 30px #0006;--shadow-lg:0 20px 60px #00000080;--shadow-glow:0 0 40px #e8b84b26;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-serif:"Playfair Display", Georgia, serif;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:50px;--transition-fast:.2s cubic-bezier(.4, 0, .2, 1);--transition-base:.3s cubic-bezier(.4, 0, .2, 1);--transition-slow:.5s cubic-bezier(.4, 0, .2, 1)}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(80% 50% at 50% -20%,#e8b84b0f 0%,#0000 60%),radial-gradient(60% 40% at 80%,#d4943a0a 0%,#0000 50%),radial-gradient(60% 40% at 20% 80%,#c97b2e08 0%,#0000 50%);width:100%;height:100%;position:fixed;top:0;left:0}#root{z-index:1;flex-direction:column;min-height:100vh;display:flex;position:relative}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);line-height:1.2}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent-secondary)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #e8b84b1a}50%{box-shadow:0 0 40px #e8b84b33}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.animate-fade-in-up{animation:fadeInUp .6s var(--transition-base) both}.animate-fade-in{animation:.4s both fadeIn}.navbar{z-index:1000;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);background:#0a0a0fbf;position:fixed;top:0;left:0;right:0}.navbar-inner{max-width:1280px;padding:0 var(--space-xl);justify-content:space-between;align-items:center;height:64px;margin:0 auto;display:flex}.navbar-brand{align-items:center;gap:var(--space-sm);transition:opacity var(--transition-fast);display:flex}.navbar-brand:hover{opacity:.85}.navbar-logo{font-size:1.6rem;animation:3s ease-in-out infinite float}.navbar-title{font-family:var(--font-serif);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700}.navbar-links{align-items:center;gap:var(--space-lg);display:flex}.navbar-link{color:var(--text-secondary);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);transition:all var(--transition-fast);letter-spacing:.02em;font-size:.875rem;font-weight:500}.navbar-link:hover{color:var(--text-primary);background:var(--bg-glass-hover)}.navbar-link.active{color:var(--accent-primary);background:#e8b84b1a}@media (width<=480px){.navbar-inner{padding:0 var(--space-md);height:56px}.navbar-title{font-size:1rem}.navbar-logo{font-size:1.3rem}.navbar-link{padding:var(--space-xs) var(--space-sm);font-size:.78rem}}.footer{border-top:1px solid var(--border-subtle);background:var(--bg-secondary);margin-top:auto}.footer-inner{max-width:1280px;padding:var(--space-xl) var(--space-xl);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;margin:0 auto;display:flex}.footer-brand{align-items:center;gap:var(--space-sm);display:flex}.footer-logo{font-size:1.3rem}.footer-title{font-family:var(--font-serif);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1rem;font-weight:700}.footer-copy{color:var(--text-muted);font-size:.75rem}@media (width<=600px){.footer-inner{text-align:center;flex-direction:column}}.company-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);transition:all var(--transition-base);cursor:pointer;flex-direction:column;display:flex;overflow:hidden}.company-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-lg), var(--shadow-glow);transform:translateY(-8px)}.company-card-image-wrapper{aspect-ratio:16/10;position:relative;overflow:hidden}.company-card-image{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.company-card:hover .company-card-image{transform:scale(1.08)}.company-card-overlay{background:linear-gradient(#0000 50%,#0a0a0fb3 100%);position:absolute;inset:0}.company-card-badge{top:var(--space-md);left:var(--space-md);position:absolute}.company-card-cuisine{text-transform:uppercase;letter-spacing:.1em;border-radius:var(--radius-full);color:var(--accent-primary);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#e8b84b26;border:1px solid #e8b84b40;padding:4px 12px;font-size:.7rem;font-weight:600}.company-card-rating{top:var(--space-md);right:var(--space-md);border-radius:var(--radius-full);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;padding:4px 10px;font-size:.8rem;font-weight:600;position:absolute}.company-card-content{padding:var(--space-lg);gap:var(--space-sm);flex-direction:column;flex:1;display:flex}.company-card-logo{font-size:2rem;line-height:1}.company-card-name{font-family:var(--font-serif);color:var(--text-primary);font-size:1.3rem;font-weight:700}.company-card-desc{color:var(--text-secondary);flex:1;font-size:.85rem;line-height:1.5}.company-card-cta{align-items:center;gap:var(--space-xs);color:var(--accent-primary);margin-top:var(--space-sm);transition:gap var(--transition-fast);font-size:.8rem;font-weight:600;display:inline-flex}.company-card:hover .company-card-cta{gap:var(--space-sm)}@media (width<=768px){.company-card-name{font-size:1.1rem}}.loader-container{justify-content:center;align-items:center;gap:var(--space-lg);flex-direction:column;min-height:60vh;animation:.3s fadeIn;display:flex}.loader{width:80px;height:80px;position:relative}.loader-ring{border:2px solid #0000;border-radius:50%;position:absolute;inset:0}.loader-ring:first-child{border-top-color:var(--accent-primary);animation:1.2s linear infinite spin}.loader-ring:nth-child(2){border-right-color:var(--accent-secondary);animation:1.6s linear infinite reverse spin;inset:8px}.loader-ring:nth-child(3){border-bottom-color:#e8b84b66;animation:2s linear infinite spin;inset:16px}.loader-emoji{font-size:1.4rem;animation:1.5s ease-in-out infinite pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.loader-text{color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;font-size:.85rem}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1;transform:translate(-50%,-50%)scale(1)}50%{opacity:.6;transform:translate(-50%,-50%)scale(.85)}}.home{padding-top:64px}.hero{justify-content:center;align-items:center;min-height:70vh;display:flex;position:relative;overflow:hidden}.hero-bg{position:absolute;inset:0}.hero-bg-image{object-fit:cover;filter:brightness(.35)saturate(.8);width:100%;height:100%}.hero-overlay{background:linear-gradient(#0a0a0f66 0%,#0a0a0ff2 100%),linear-gradient(90deg,#0a0a0f99 0%,#0000 60%);position:absolute;inset:0}.hero-content{z-index:2;text-align:center;max-width:700px;padding:var(--space-3xl) var(--space-xl);position:relative}.hero-badge{text-transform:uppercase;letter-spacing:.15em;border-radius:var(--radius-full);color:var(--accent-primary);margin-bottom:var(--space-lg);background:#e8b84b1a;border:1px solid #e8b84b33;padding:6px 20px;font-size:.75rem;font-weight:600;display:inline-block}.hero-title{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:clamp(2rem,5vw,3.2rem);font-weight:700;line-height:1.15}.hero-accent{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--text-secondary);max-width:540px;margin:0 auto;font-size:1.05rem;line-height:1.7}.hero-actions{gap:var(--space-md);margin-top:var(--space-2xl);flex-wrap:wrap;justify-content:center;display:flex}.hero-cta{border-radius:var(--radius-sm);padding:14px 28px;font-size:.95rem;font-weight:700;box-shadow:0 4px 20px #e8b84b33}.hero-secondary-cta{border:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;padding:14px 28px;font-size:.95rem;font-weight:600}.hero-secondary-cta:hover{border-color:var(--text-muted);background:#ffffff1a}.hero-scroll-indicator{z-index:2;position:absolute;bottom:30px;left:50%;transform:translate(-50%)}.hero-scroll-line{background:linear-gradient(to bottom, var(--accent-primary), transparent);width:1px;height:40px;animation:2s ease-in-out infinite pulse}.companies-section{max-width:1280px;padding:var(--space-3xl) var(--space-xl);margin:0 auto}.section-header{text-align:center;margin-bottom:var(--space-3xl)}.section-title{color:var(--text-primary);margin-bottom:var(--space-sm);font-size:clamp(1.5rem,3vw,2rem);font-weight:700}.section-subtitle{color:var(--text-secondary);font-size:.95rem}.companies-grid{gap:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}@media (width<=768px){.hero{min-height:55vh}.hero-title{font-size:1.8rem}.hero-subtitle{font-size:.9rem}.companies-section{padding:var(--space-2xl) var(--space-md)}.section-header{margin-bottom:var(--space-xl)}.companies-grid{gap:var(--space-md);grid-template-columns:1fr}}@media (width<=480px){.home{padding-top:56px}.hero{min-height:50vh}.hero-content{padding:var(--space-xl) var(--space-md)}.hero-badge{padding:4px 14px;font-size:.65rem}.hero-title{margin-bottom:var(--space-md);font-size:1.5rem}.hero-subtitle{font-size:.82rem;line-height:1.6}.section-title{font-size:1.3rem}.section-subtitle{font-size:.82rem}}.category-tabs-wrapper{z-index:50;-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);padding:var(--space-md) 0;background:#0a0a0fd9;position:sticky;top:64px}.category-tabs{gap:var(--space-sm);padding:0 var(--space-xl);scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.category-tabs::-webkit-scrollbar{display:none}.category-tab{align-items:center;gap:var(--space-xs);border-radius:var(--radius-full);white-space:nowrap;color:var(--text-secondary);background:var(--bg-glass);transition:all var(--transition-fast);border:1px solid #0000;padding:10px 20px;font-size:.85rem;font-weight:500;display:flex}.category-tab:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.category-tab.active{color:var(--accent-primary);border-color:var(--border-accent);background:#e8b84b1f;box-shadow:0 0 20px #e8b84b14}.category-tab-icon{font-size:1.1rem}.category-tab-name{font-size:.85rem}@media (width<=768px){.category-tabs{padding:0 var(--space-md)}.category-tab{padding:8px 14px;font-size:.8rem}}.subcategory-filter{gap:var(--space-sm);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.subcategory-pill{border-radius:var(--radius-full);color:var(--text-secondary);background:var(--bg-glass);border:1px solid var(--border-subtle);transition:all var(--transition-fast);padding:6px 16px;font-size:.8rem;font-weight:500}.subcategory-pill:hover{color:var(--text-primary);background:var(--bg-glass-hover);border-color:#ffffff1a}.subcategory-pill.active{color:var(--bg-primary);background:var(--accent-gradient);border-color:#0000;font-weight:600}.dish-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all var(--transition-base);animation:.5s both fadeInUp;overflow:hidden}.dish-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-md), 0 0 30px #e8b84b0f;transform:translateY(-4px)scale(1.01)}.dish-card-image-wrapper{aspect-ratio:16/10;position:relative;overflow:hidden}.dish-card-image{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.dish-card:hover .dish-card-image{transform:scale(1.06)}.dish-card-price-badge{bottom:var(--space-sm);right:var(--space-sm);border-radius:var(--radius-full);background:var(--accent-gradient);color:var(--bg-primary);box-shadow:var(--shadow-sm);padding:4px 12px;font-size:.85rem;font-weight:700;position:absolute}.dish-card-body{padding:var(--space-md);gap:var(--space-xs);flex-direction:column;display:flex}.dish-card-name{font-family:var(--font-serif);color:var(--text-primary);font-size:1rem;font-weight:700;line-height:1.3}.dish-card-desc{color:var(--text-secondary);-webkit-line-clamp:3;-webkit-box-orient:vertical;font-size:.78rem;line-height:1.5;display:-webkit-box;overflow:hidden}.dish-card-tags{margin-top:var(--space-xs);flex-wrap:wrap;gap:4px;display:flex}.dish-card-tag{text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);color:var(--accent-primary);background:#e8b84b14;border:1px solid #e8b84b26;padding:2px 8px;font-size:.65rem;font-weight:600}@media (width<=768px){.dish-card-name{font-size:.9rem}}.company-menu{padding-top:64px}.menu-header{align-items:flex-end;min-height:340px;display:flex;position:relative;overflow:hidden}.menu-header-bg{position:absolute;inset:0}.menu-header-image{object-fit:cover;filter:brightness(.3)saturate(.7);width:100%;height:100%}.menu-header-overlay{background:linear-gradient(to top, var(--bg-primary) 0%, transparent 70%);position:absolute;inset:0}.menu-header-content{z-index:2;width:100%;max-width:1280px;padding:var(--space-xl);padding-bottom:var(--space-2xl);margin:0 auto;position:relative}.menu-back-btn{align-items:center;gap:var(--space-xs);color:var(--text-secondary);border-radius:var(--radius-full);background:var(--bg-glass);border:1px solid var(--border-subtle);margin-bottom:var(--space-lg);transition:all var(--transition-fast);cursor:pointer;padding:6px 14px;font-size:.8rem;font-weight:500;display:inline-flex}.menu-back-btn:hover{color:var(--text-primary);background:var(--bg-glass-hover)}.menu-header-info{gap:var(--space-sm);flex-direction:column;display:flex}.menu-header-logo{font-size:2.5rem;line-height:1}.menu-header-name{color:var(--text-primary);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:700}.menu-header-desc{color:var(--text-secondary);max-width:550px;font-size:.95rem;line-height:1.6}.menu-header-meta{align-items:center;gap:var(--space-md);margin-top:var(--space-xs);display:flex}.menu-header-cuisine{text-transform:uppercase;letter-spacing:.1em;border-radius:var(--radius-full);color:var(--accent-primary);background:#e8b84b1f;border:1px solid #e8b84b33;padding:4px 14px;font-size:.75rem;font-weight:600}.menu-header-rating{color:var(--text-primary);font-size:.85rem;font-weight:600}.menu-content{max-width:1280px;padding:var(--space-2xl) var(--space-xl);margin:0 auto}.menu-content-inner{flex-direction:column;display:flex}.menu-category-header{margin-bottom:var(--space-xl);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:baseline;display:flex}.menu-category-title{color:var(--text-primary);align-items:center;gap:var(--space-sm);font-size:1.5rem;font-weight:700;display:flex}.menu-category-icon{font-size:1.3rem}.menu-dish-count{color:var(--text-muted);font-size:.8rem;font-weight:500}.dishes-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.menu-empty{text-align:center;padding:var(--space-3xl);color:var(--text-muted);font-size:.9rem}.menu-not-found{justify-content:center;align-items:center;gap:var(--space-md);text-align:center;flex-direction:column;min-height:80vh;padding-top:64px;display:flex}.menu-not-found h2{color:var(--text-primary);font-size:1.5rem}.menu-not-found p{color:var(--text-secondary)}.menu-back-link{color:var(--accent-primary);margin-top:var(--space-md);transition:opacity var(--transition-fast);font-size:.85rem;font-weight:600}.menu-back-link:hover{opacity:.8}@media (width<=768px){.menu-header{min-height:250px}.menu-header-content{padding:var(--space-md);padding-bottom:var(--space-lg)}.menu-header-logo{font-size:2rem}.menu-content{padding:var(--space-lg) var(--space-md)}.dishes-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.menu-category-header{align-items:flex-start;gap:var(--space-xs);flex-direction:column}}@media (width<=480px){.company-menu{padding-top:56px}.menu-header{min-height:220px}.menu-header-name{font-size:1.4rem}.menu-header-desc{font-size:.82rem}.menu-content{padding:var(--space-md)}.dishes-grid{grid-template-columns:1fr}.menu-category-title{font-size:1.2rem}}.has-custom-colors{background-color:var(--company-bg);color:var(--company-text)}.has-custom-colors .menu-header-overlay{background:linear-gradient(to top, var(--company-bg) 0%, transparent 70%)}.has-custom-colors .menu-header-name{color:var(--company-text)}.has-custom-colors .menu-header-desc{color:color-mix(in srgb, var(--company-text) 70%, transparent)}.has-custom-colors .menu-header-cuisine{background:color-mix(in srgb, var(--company-primary) 15%, transparent);color:var(--company-primary);border-color:color-mix(in srgb, var(--company-primary) 30%, transparent)}.has-custom-colors .menu-header-rating,.has-custom-colors .menu-category-title{color:var(--company-text)}.has-custom-colors .menu-category-header{border-bottom-color:color-mix(in srgb, var(--company-text) 10%, transparent)}.has-custom-colors~.footer{background:color-mix(in srgb, var(--company-bg) 80%, #000)}.has-custom-colors .category-tabs-wrapper{background:color-mix(in srgb, var(--company-bg) 85%, transparent)}.has-custom-colors .category-tab.active{background:color-mix(in srgb, var(--company-primary) 12%, transparent);color:var(--company-primary);border-color:color-mix(in srgb, var(--company-primary) 30%, transparent)}.has-custom-colors .subcategory-pill.active{background:linear-gradient(135deg, var(--company-primary), var(--company-secondary));color:var(--company-bg)}.has-custom-colors .dish-card{background:color-mix(in srgb, var(--company-bg) 80%, #1a1a2e);border-color:color-mix(in srgb, var(--company-text) 8%, transparent)}.has-custom-colors .dish-card:hover{border-color:color-mix(in srgb, var(--company-primary) 30%, transparent)}.has-custom-colors .dish-card-name{color:var(--company-text)}.has-custom-colors .dish-card-desc{color:color-mix(in srgb, var(--company-text) 65%, transparent)}.has-custom-colors .dish-card-price-badge{background:linear-gradient(135deg, var(--company-primary), var(--company-accent));color:var(--company-bg)}.has-custom-colors .dish-card-tag{background:color-mix(in srgb, var(--company-primary) 10%, transparent);color:var(--company-primary);border-color:color-mix(in srgb, var(--company-primary) 20%, transparent)}.admin-layout{background:var(--bg-primary);min-height:100vh;display:flex}.admin-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);z-index:100;flex-direction:column;width:260px;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0}.admin-sidebar-header{padding:var(--space-lg) var(--space-xl);align-items:center;gap:var(--space-sm);border-bottom:1px solid var(--border-subtle);display:flex}.admin-sidebar-logo{font-size:1.4rem}.admin-sidebar-brand{font-family:var(--font-serif);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:700}.admin-nav{padding:var(--space-md);flex-direction:column;flex:1;gap:2px;display:flex}.admin-nav-item{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--transition-fast);padding:10px 14px;font-size:.85rem;font-weight:500;display:flex}.admin-nav-item:hover{color:var(--text-primary);background:var(--bg-glass-hover)}.admin-nav-item.active{color:var(--accent-primary);background:#e8b84b1a}.admin-nav-item.active svg{stroke:var(--accent-primary)}.admin-sidebar-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-subtle);gap:var(--space-sm);flex-direction:column;display:flex}.admin-user-info{align-items:center;gap:var(--space-sm);display:flex}.admin-user-avatar{background:var(--bg-glass);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;font-size:1.3rem;display:flex}.admin-user-details{flex-direction:column;display:flex}.admin-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:150px;font-size:.8rem;font-weight:600;overflow:hidden}.admin-user-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.admin-logout-btn{align-items:center;gap:var(--space-xs);color:var(--text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast);padding:6px 10px;font-size:.78rem;display:flex}.admin-logout-btn:hover{color:#ef4444;background:#ef444414}.admin-main{flex-direction:column;flex:1;margin-left:260px;display:flex}.admin-topbar{height:56px;padding:0 var(--space-2xl);border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);align-items:center;display:flex}.admin-topbar-title{font-family:var(--font-sans);color:var(--text-secondary);font-size:.9rem;font-weight:600}.admin-content{padding:var(--space-2xl);flex:1;overflow-y:auto}.admin-page-header{margin-bottom:var(--space-2xl)}.admin-page-title{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:1.5rem;font-weight:700}.admin-page-subtitle{color:var(--text-muted);font-size:.85rem}.admin-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-xl)}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-subtle);font-size:.7rem;font-weight:600}.admin-table td{padding:var(--space-md);color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);vertical-align:middle;font-size:.85rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-glass)}.btn-primary{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);background:var(--accent-gradient);color:var(--bg-primary);transition:all var(--transition-fast);padding:8px 16px;font-size:.8rem;font-weight:600;display:inline-flex}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-secondary{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border-subtle);transition:all var(--transition-fast);padding:6px 12px;font-size:.78rem;font-weight:500;display:inline-flex}.btn-secondary:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.btn-danger{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);color:#ef4444;transition:all var(--transition-fast);background:#ef444414;border:1px solid #ef444426;padding:6px 12px;font-size:.78rem;font-weight:500;display:inline-flex}.btn-danger:hover{background:#ef444426}.btn-group{gap:var(--space-xs);display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;padding:var(--space-xl);background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-2xl);width:100%;max-width:520px;max-height:80vh;animation:.3s fadeInUp;overflow-y:auto}.modal h3{color:var(--text-primary);margin-bottom:var(--space-lg);font-size:1.15rem;font-weight:700}.modal-field{gap:var(--space-xs);margin-bottom:var(--space-md);flex-direction:column;display:flex}.modal-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.modal-field input,.modal-field textarea,.modal-field select{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-glass);color:var(--text-primary);font-size:.85rem;font-family:var(--font-sans);transition:border-color var(--transition-fast);outline:none;padding:10px 14px}.modal-field input:focus,.modal-field textarea:focus,.modal-field select:focus{border-color:var(--accent-primary)}.modal-field textarea{resize:vertical;min-height:80px}.modal-field select{cursor:pointer}.modal-actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-xl);display:flex}.stats-grid{gap:var(--space-lg);margin-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-xl);gap:var(--space-sm);flex-direction:column;display:flex}.stat-card-icon{font-size:1.5rem}.stat-card-value{color:var(--text-primary);font-size:2rem;font-weight:800;font-family:var(--font-sans)}.stat-card-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}.admin-sidebar-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:4px;font-size:1.2rem;display:none}.admin-hamburger{color:var(--text-secondary);cursor:pointer;margin-right:var(--space-sm);background:0 0;border:none;padding:4px;display:none}.admin-sidebar-overlay{display:none}@media (width<=768px){.admin-sidebar{width:280px;transition:transform var(--transition-base);z-index:200;transform:translate(-100%)}.admin-sidebar.open{transform:translate(0)}.admin-sidebar-close{display:block}.admin-sidebar-overlay{z-index:150;background:#00000080;animation:.2s fadeIn;display:block;position:fixed;inset:0}.admin-main{margin-left:0}.admin-hamburger{align-items:center;display:flex}.admin-topbar{padding:0 var(--space-md)}.admin-content{padding:var(--space-md)}.admin-page-title{font-size:1.2rem}.admin-page-subtitle{font-size:.78rem}.admin-card{padding:var(--space-md);-webkit-overflow-scrolling:touch;overflow-x:auto}.admin-table{min-width:500px}.admin-table th,.admin-table td{padding:var(--space-sm);font-size:.78rem}.btn-primary{padding:8px 14px;font-size:.75rem}.btn-secondary,.btn-danger{padding:5px 10px;font-size:.72rem}.btn-group{flex-wrap:wrap}.modal-backdrop{padding:var(--space-sm);align-items:flex-end}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-width:100%;max-height:90vh;padding:var(--space-xl) var(--space-lg)}.modal-actions{flex-direction:column}.modal-actions .btn-primary,.modal-actions .btn-secondary{justify-content:center;width:100%;padding:12px}.stats-grid{gap:var(--space-sm);grid-template-columns:1fr 1fr}.stat-card{padding:var(--space-md)}.stat-card-value{font-size:1.5rem}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.admin-sidebar{width:100%}}.login-page{min-height:100vh;padding:var(--space-xl);background:var(--bg-primary);justify-content:center;align-items:center;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:420px;padding:var(--space-3xl) var(--space-2xl);box-shadow:var(--shadow-lg);animation:.5s fadeInUp}.login-header{text-align:center;margin-bottom:var(--space-2xl)}.login-logo{margin-bottom:var(--space-md);font-size:2.5rem;display:block}.login-title{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:1.5rem;font-weight:700}.login-subtitle{color:var(--text-muted);font-size:.85rem}.login-form{gap:var(--space-lg);flex-direction:column;display:flex}.login-error{color:#ef4444;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);text-align:center;background:#ef44441a;border:1px solid #ef444433;font-size:.8rem}.login-field{gap:var(--space-xs);flex-direction:column;display:flex}.login-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.login-field input{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-glass);color:var(--text-primary);font-size:.9rem;font-family:var(--font-sans);transition:all var(--transition-fast);outline:none;padding:12px 16px}.login-field input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.login-field input::placeholder{color:var(--text-muted)}.login-btn{border-radius:var(--radius-sm);background:var(--accent-gradient);color:var(--bg-primary);letter-spacing:.02em;transition:all var(--transition-fast);margin-top:var(--space-sm);padding:14px;font-size:.9rem;font-weight:700}.login-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-hint{margin-top:var(--space-xl);text-align:center;color:var(--text-muted);font-size:.75rem}.login-hint strong{color:var(--text-secondary)}.login-btn-loading{justify-content:center;align-items:center;gap:8px;display:flex}.login-spinner{border:2px solid;border-color:currentColor currentColor #0000 #0000;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite login-spin;display:inline-block}@keyframes login-spin{to{transform:rotate(360deg)}}.login-field input:disabled{opacity:.5;cursor:not-allowed}.admin-loader--page{justify-content:center;align-items:center;min-height:400px;animation:.3s fadeIn;display:flex}.admin-loader--inline{padding:var(--space-2xl) var(--space-md);justify-content:center;align-items:center;animation:.3s fadeIn;display:flex}.admin-loader--inline .admin-loader-spinner{width:40px;height:40px}.admin-loader--inline .admin-loader-ring{border-width:2px}.admin-loader--inline .admin-loader-ring:nth-child(2){inset:5px}.admin-loader--inline .admin-loader-icon{font-size:.8rem}.admin-loader--inline .admin-loader-message{font-size:.78rem}.admin-loader--overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-md);z-index:50;background:#0a0a0fbf;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:absolute;inset:0}.admin-loader--overlay .admin-loader-spinner{width:48px;height:48px}.admin-loader--overlay .admin-loader-ring{border-width:2px}.admin-loader--overlay .admin-loader-ring:nth-child(2){inset:6px}.admin-loader--overlay .admin-loader-icon{font-size:1rem}.admin-loader-content{align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.admin-loader-spinner{width:60px;height:60px;position:relative}.admin-loader-ring{border:2.5px solid #0000;border-radius:50%;position:absolute;inset:0}.admin-loader-ring:first-child{border-top-color:var(--accent-primary);animation:1s linear infinite admin-spin}.admin-loader-ring:nth-child(2){border-right-color:var(--accent-secondary);animation:1.4s linear infinite reverse admin-spin;inset:8px}.admin-loader-icon{font-size:1.1rem;animation:1.5s ease-in-out infinite admin-pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.admin-loader-message{color:var(--text-muted);letter-spacing:.04em;font-size:.82rem;animation:2s ease-in-out infinite admin-pulse}@keyframes admin-spin{to{transform:rotate(360deg)}}@keyframes admin-pulse{0%,to{opacity:1}50%{opacity:.5}}.admin-loader-btn{vertical-align:middle;border:2px solid;border-color:currentColor currentColor #0000 #0000;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite admin-spin;display:inline-block}.admin-skeleton-row td{position:relative;overflow:hidden}.admin-skeleton-row td:after{content:"";background:linear-gradient(90deg, var(--bg-glass) 25%, var(--bg-glass-hover) 50%, var(--bg-glass) 75%);background-size:200% 100%;border-radius:4px;width:60%;height:12px;animation:1.5s ease-in-out infinite shimmer;display:block}.admin-skeleton-row td:first-child:after{border-radius:6px;width:28px;height:28px}.admin-skeleton-row td:last-child:after{width:80%}.dashboard-section-title{font-family:var(--font-sans);color:var(--text-primary);margin-bottom:var(--space-lg);font-size:.9rem;font-weight:600}.stat-card--loading .stat-card-value{color:var(--text-muted);justify-content:flex-start;align-items:center;display:flex}.dashboard-table-loading{margin-bottom:var(--space-md);border-bottom:1px solid var(--border-subtle);padding-bottom:var(--space-md)}.image-uploader{gap:var(--space-sm);flex-direction:column;display:flex}.image-uploader-toggle{background:var(--bg-glass);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);gap:2px;padding:2px;display:flex}.image-uploader-toggle-btn{font-size:.72rem;font-weight:600;font-family:var(--font-sans);color:var(--text-muted);border-radius:calc(var(--radius-sm) - 2px);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:4px;padding:6px 10px;display:flex}.image-uploader-toggle-btn:hover{color:var(--text-secondary)}.image-uploader-toggle-btn.active{background:var(--accent-gradient);color:var(--bg-primary);box-shadow:0 1px 3px #0003}.image-drop-zone{border:2px dashed var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-xl);justify-content:center;align-items:center;gap:var(--space-sm);cursor:pointer;transition:all var(--transition-base);background:var(--bg-glass);flex-direction:column;min-height:140px;display:flex;position:relative;overflow:hidden}.image-drop-zone:hover{border-color:var(--accent-primary);background:#e8b84b0a}.image-drop-zone.dragging{border-color:var(--accent-primary);background:#e8b84b14;border-style:solid;box-shadow:inset 0 0 20px #e8b84b0f}.image-drop-zone.has-preview{padding:var(--space-sm);border-style:solid;border-color:var(--border-subtle)}.image-drop-zone.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.image-drop-zone input[type=file]{display:none}.image-drop-icon{opacity:.7;transition:transform var(--transition-fast);font-size:2rem;line-height:1}.image-drop-zone:hover .image-drop-icon{transform:translateY(-2px)}.image-drop-text{color:var(--text-secondary);text-align:center;font-size:.82rem;font-weight:500}.image-drop-hint{color:var(--text-muted);text-align:center;font-size:.7rem}.image-preview-container{justify-content:center;align-items:center;width:100%;display:flex;position:relative}.image-preview{border-radius:var(--radius-sm);object-fit:contain;max-width:100%;max-height:180px;transition:opacity var(--transition-fast);box-shadow:0 2px 8px #00000026}.image-preview-actions{top:var(--space-xs);right:var(--space-xs);opacity:0;transition:opacity var(--transition-fast);gap:4px;display:flex;position:absolute}.image-preview-container:hover .image-preview-actions{opacity:1}.image-preview-btn{border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;cursor:pointer;width:28px;height:28px;transition:background var(--transition-fast);background:#000000a6;border:none;justify-content:center;align-items:center;font-size:.85rem;display:flex}.image-preview-btn:hover{background:#ef4444cc}.image-progress-wrapper{align-items:center;gap:var(--space-xs);width:100%;padding:var(--space-sm) 0;flex-direction:column;display:flex}.image-progress-bar{background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:3px;width:100%;height:6px;overflow:hidden}.image-progress-fill{background:var(--accent-gradient);border-radius:3px;height:100%;transition:width .3s;position:relative}.image-progress-fill:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff4d 50%,#0000 100%);animation:1.5s infinite shimmer;position:absolute;inset:0}.image-progress-text{color:var(--accent-primary);font-size:.72rem;font-weight:600}.image-upload-error{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);color:#ef4444;background:#ef444414;border:1px solid #ef444433;padding:8px 12px;font-size:.75rem;display:flex}.image-upload-error-icon{flex-shrink:0;font-size:.9rem}.image-upload-error-text{flex:1}.image-upload-error-dismiss{color:#ef4444;cursor:pointer;opacity:.6;transition:opacity var(--transition-fast);background:0 0;border:none;flex-shrink:0;padding:0;font-size:1rem}.image-upload-error-dismiss:hover{opacity:1}.image-upload-success{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);color:#22c55e;background:#22c55e14;border:1px solid #22c55e33;padding:6px 10px;font-size:.72rem;font-weight:500;display:flex}.image-url-input-wrapper{gap:var(--space-xs);flex-direction:column;display:flex}.image-url-preview{align-items:center;gap:var(--space-sm);width:100%;margin-top:var(--space-xs);display:flex}.image-url-preview img{border-radius:var(--radius-sm);object-fit:cover;border:1px solid var(--border-subtle);width:48px;height:48px}.image-url-preview-placeholder{border-radius:var(--radius-sm);background:var(--bg-glass);border:1px dashed var(--border-subtle);width:48px;height:48px;color:var(--text-muted);justify-content:center;align-items:center;font-size:1.2rem;display:flex}@media (width<=768px){.image-drop-zone{min-height:120px;padding:var(--space-lg)}.image-drop-icon{font-size:1.6rem}.image-drop-text{font-size:.78rem}.image-preview{max-height:140px}.image-preview-actions{opacity:1}}.company-manager .row-deleting{opacity:.4;pointer-events:none;transition:opacity var(--transition-fast)}.btn-primary:disabled,.btn-secondary:disabled,.btn-danger:disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.btn-primary .admin-loader-btn,.btn-danger .admin-loader-btn{margin-right:4px}.pm-company-select{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-glass);color:var(--text-primary);font-size:.82rem;font-family:var(--font-sans);cursor:pointer;outline:none;padding:8px 12px}.pm-company-select:focus{border-color:var(--accent-primary)}.pm-company-select:disabled{opacity:.5;cursor:not-allowed}.pm-tree{gap:var(--space-lg);flex-direction:column;min-height:100px;display:flex;position:relative}.pm-empty{text-align:center;padding:var(--space-3xl);color:var(--text-muted);background:var(--bg-card);border:1px dashed var(--border-subtle);border-radius:var(--radius-md);font-size:.85rem}.pm-category{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.pm-category-header{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-glass);border-bottom:1px solid var(--border-subtle);display:flex}.pm-category-icon{font-size:1.1rem}.pm-category-name{color:var(--text-primary);font-size:.95rem;font-weight:700}.pm-subcategory{border-bottom:1px solid var(--border-subtle)}.pm-subcategory:last-child{border-bottom:none}.pm-subcategory-header{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);padding-left:var(--space-2xl);background:#ffffff03;display:flex}.pm-subcategory-name{color:var(--accent-primary);font-size:.85rem;font-weight:600}.pm-dishes-table{padding-left:var(--space-2xl)}.pm-no-dishes,.pm-no-sub{color:var(--text-muted);padding:var(--space-sm) var(--space-lg);padding-left:var(--space-3xl);font-size:.78rem;font-style:italic}.pm-no-sub{padding-left:var(--space-2xl)}@media (width<=768px){.pm-company-select{width:100%;font-size:.8rem}.pm-category-header{padding:var(--space-sm) var(--space-md);gap:var(--space-xs);flex-wrap:wrap}.pm-category-name{font-size:.85rem}.pm-subcategory-header{padding:var(--space-sm) var(--space-md);padding-left:var(--space-lg);gap:var(--space-xs);flex-wrap:wrap}.pm-dishes-table{padding-left:var(--space-sm);-webkit-overflow-scrolling:touch;overflow-x:auto}.pm-dishes-table .admin-table{min-width:450px}.pm-no-dishes,.pm-no-sub{padding-left:var(--space-lg)}.pm-empty{padding:var(--space-xl)}}.cc-layout{gap:var(--space-xl);grid-template-columns:1fr 1fr;align-items:start;display:grid}.cc-section-title{font-family:var(--font-sans);color:var(--text-primary);margin-bottom:var(--space-lg);font-size:.9rem;font-weight:600}.cc-fields{gap:var(--space-lg);flex-direction:column;display:flex}.cc-field{justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.cc-field-info{flex-direction:column;gap:2px;display:flex}.cc-field-label{color:var(--text-primary);font-size:.82rem;font-weight:600}.cc-field-desc{color:var(--text-muted);font-size:.7rem}.cc-field-controls{align-items:center;gap:var(--space-sm);display:flex}.cc-color-input{border:2px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;background:0 0;width:36px;height:36px;padding:0}.cc-color-input::-webkit-color-swatch-wrapper{padding:2px}.cc-color-input::-webkit-color-swatch{border:none;border-radius:4px}.cc-hex-input{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-glass);width:80px;color:var(--text-primary);outline:none;padding:6px 10px;font-family:monospace;font-size:.8rem}.cc-hex-input:focus{border-color:var(--accent-primary)}.cc-actions{justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border-subtle);display:flex}.cc-preview-menu{border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--border-subtle);font-size:.85rem}.cc-preview-header{align-items:center;gap:var(--space-sm);padding-bottom:var(--space-md);margin-bottom:var(--space-md);display:flex}.cc-preview-tabs{gap:var(--space-xs);margin-bottom:var(--space-md);display:flex}.cc-preview-tab{border-radius:var(--radius-full);cursor:default;padding:6px 12px;font-size:.75rem;font-weight:500}.cc-preview-tab.active{border:1px solid}.cc-preview-pills{gap:var(--space-xs);margin-bottom:var(--space-md);display:flex}.cc-preview-pill{border-radius:var(--radius-full);cursor:default;padding:4px 10px;font-size:.7rem;font-weight:600}.cc-preview-pill:not(.active){border:1px solid}.cc-preview-dish{gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);margin-bottom:var(--space-sm);display:flex}.cc-preview-dish:hover{background:#ffffff08}.cc-preview-dish-img{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.2rem;display:flex}.cc-preview-dish-info{flex-direction:column;gap:2px;display:flex}.cc-preview-price{border-radius:var(--radius-full);width:fit-content;margin-top:4px;padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-block}@media (width<=900px){.cc-layout{grid-template-columns:1fr}}.qr-generator{animation:.4s both fadeInUp}.qr-layout{gap:var(--space-xl);grid-template-columns:380px 1fr;align-items:start;display:grid}.qr-config-panel{top:var(--space-xl);position:sticky}.qr-section-title{font-family:var(--font-sans);color:var(--text-primary);align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);font-size:.85rem;font-weight:700;display:flex}.qr-section-title svg{color:var(--accent-primary)}.qr-divider{background:var(--border-subtle);height:1px;margin:var(--space-lg) 0}.qr-field{margin-bottom:var(--space-md)}.qr-field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-xs);font-size:.72rem;font-weight:600;display:block}.qr-select{border-radius:var(--radius-sm);border:1px solid var(--border-subtle);background:var(--bg-glass);width:100%;color:var(--text-primary);font-size:.85rem;font-family:var(--font-sans);cursor:pointer;transition:border-color var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236a6a82' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;outline:none;padding:10px 36px 10px 14px}.qr-select:focus{border-color:var(--accent-primary)}.qr-select option{background:var(--bg-secondary);color:var(--text-primary)}.qr-company-badge{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);border:1px solid var(--border-accent);background:#e8b84b14;padding:10px 14px;display:flex}.qr-company-badge-logo{font-size:1.4rem}.qr-company-badge-name{color:var(--text-primary);font-size:.85rem;font-weight:600}.qr-url-preview{align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border-subtle);padding:8px 12px;display:flex}.qr-url-text{color:var(--accent-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:Courier New,monospace;font-size:.78rem;overflow:hidden}.qr-copy-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.qr-copy-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.qr-copy-btn.copied{color:#22c55e}.qr-size-control{align-items:center;gap:var(--space-md);display:flex}.qr-range{appearance:none;background:var(--bg-glass-hover);border-radius:2px;outline:none;flex:1;height:4px}.qr-range::-webkit-slider-thumb{appearance:none;background:var(--accent-primary);cursor:pointer;width:16px;height:16px;box-shadow:0 0 10px var(--accent-glow);transition:transform var(--transition-fast);border-radius:50%}.qr-range::-webkit-slider-thumb:hover{transform:scale(1.2)}.qr-range::-moz-range-thumb{background:var(--accent-primary);cursor:pointer;width:16px;height:16px;box-shadow:0 0 10px var(--accent-glow);border:none;border-radius:50%}.qr-size-value{color:var(--text-secondary);text-align:right;min-width:48px;font-family:Courier New,monospace;font-size:.78rem;font-weight:600}.qr-color-row{gap:var(--space-md);display:flex}.qr-field-half{flex:1}.qr-color-picker{align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);background:var(--bg-glass);border:1px solid var(--border-subtle);padding:6px 10px;display:flex}.qr-color-input{appearance:none;border:2px solid var(--border-subtle);cursor:pointer;background:0 0;border-radius:6px;width:28px;height:28px;padding:0}.qr-color-input::-webkit-color-swatch-wrapper{padding:0}.qr-color-input::-webkit-color-swatch{border:none;border-radius:4px}.qr-color-input::-moz-color-swatch{border:none;border-radius:4px}.qr-color-hex{color:var(--text-muted);text-transform:uppercase;font-family:Courier New,monospace;font-size:.72rem}.qr-toggle-label{align-items:center;gap:var(--space-sm);cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none;font-size:.82rem;display:flex}.qr-checkbox{opacity:0;width:0;height:0;position:absolute}.qr-toggle-slider{background:var(--bg-glass-hover);width:36px;height:20px;transition:background var(--transition-fast);border-radius:10px;flex-shrink:0;position:relative}.qr-toggle-slider:after{content:"";background:var(--text-muted);width:14px;height:14px;transition:all var(--transition-fast);border-radius:50%;position:absolute;top:3px;left:3px}.qr-checkbox:checked+.qr-toggle-slider{background:#e8b84b4d}.qr-checkbox:checked+.qr-toggle-slider:after{background:var(--accent-primary);left:19px}.qr-presets{gap:var(--space-xs);grid-template-columns:repeat(4,1fr);display:grid}.qr-preset-btn{border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition-fast);flex-direction:column;align-items:center;gap:4px;padding:8px 4px;font-size:.68rem;display:flex}.qr-preset-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.qr-preset-swatch{width:28px;height:28px;transition:transform var(--transition-fast);border-radius:6px}.qr-preset-btn:hover .qr-preset-swatch{transform:scale(1.1)}.qr-preview-card{flex-direction:column;align-items:center;display:flex}.qr-preview-header{align-items:center;gap:var(--space-md);width:100%;margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-subtle);display:flex}.qr-preview-company-logo{background:var(--bg-glass);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:48px;height:48px;font-size:2rem;display:flex}.qr-preview-company-name{font-family:var(--font-sans);color:var(--text-primary);margin-bottom:2px;font-size:1.05rem;font-weight:700}.qr-preview-company-cuisine{color:var(--text-muted);font-size:.78rem}.qr-canvas-wrapper{padding:var(--space-xl) 0;justify-content:center;display:flex}.qr-canvas-container{border-radius:var(--radius-md);box-shadow:var(--shadow-md);transition:opacity var(--transition-base), transform var(--transition-base);display:inline-flex;position:relative;overflow:hidden}.qr-canvas-container.loading{opacity:.4}.qr-canvas-container.loaded{opacity:1;animation:.4s both qrAppear}@keyframes qrAppear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.qr-canvas{border-radius:var(--radius-md);display:block}.qr-loading-overlay{justify-content:center;align-items:center;gap:var(--space-sm);color:var(--text-muted);flex-direction:column;font-size:.78rem;display:flex;position:absolute;inset:0}.qr-spinner{border:3px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}.qr-actions{gap:var(--space-sm);width:100%;margin-top:var(--space-md);display:flex}.qr-action-btn{justify-content:center;align-items:center;gap:var(--space-xs);border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;font-family:var(--font-sans);transition:all var(--transition-fast);white-space:nowrap;flex:1;padding:12px 16px;display:flex}.qr-action-primary{background:var(--accent-gradient);color:var(--bg-primary)}.qr-action-primary:hover{opacity:.9;box-shadow:var(--shadow-glow);transform:translateY(-1px)}.qr-action-secondary{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border-subtle)}.qr-action-secondary:hover{background:var(--bg-glass-hover);color:var(--text-primary);border-color:#ffffff1f}.qr-tip{gap:var(--space-sm);margin-top:var(--space-lg);padding:var(--space-md);border-radius:var(--radius-sm);background:#e8b84b0f;border:1px solid #e8b84b1f;align-items:flex-start;width:100%;display:flex}.qr-tip svg{color:var(--accent-primary);flex-shrink:0;margin-top:1px}.qr-tip span{color:var(--text-secondary);font-size:.78rem;line-height:1.5}.qr-empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl);flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.qr-empty-icon{color:var(--text-muted);opacity:.3;margin-bottom:var(--space-lg);animation:4s ease-in-out infinite float}.qr-empty-title{font-family:var(--font-sans);color:var(--text-primary);margin-bottom:var(--space-sm);font-size:1.1rem;font-weight:700}.qr-empty-text{color:var(--text-muted);max-width:300px;font-size:.85rem}@media (width<=900px){.qr-layout{grid-template-columns:1fr}.qr-config-panel{position:static}}@media (width<=768px){.qr-actions{flex-direction:column}.qr-action-btn{width:100%}.qr-presets{grid-template-columns:repeat(2,1fr)}.qr-color-row{gap:var(--space-sm);flex-direction:column}}@media (width<=480px){.qr-preview-header{text-align:center;flex-direction:column}}
