.theme-toggle{background:none;border:none;cursor:pointer;padding:0;transition:all .3s ease;z-index:10}.theme-toggle:hover{transform:scale(1.05)}.toggle-track{background:var(--gradient-primary);border:2px solid #0000;border-radius:16px;box-shadow:0 4px 15px #667eea4d;height:32px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);width:65px}[data-theme=dark] .toggle-track{background:var(--gradient-secondary);box-shadow:0 4px 15px #f093fb4d}.toggle-thumb{align-items:center;background:#fff;border:2px solid #fffc;border-radius:50%;box-shadow:0 4px 12px #00000026;display:flex;height:28px;justify-content:center;position:absolute;transition:all .4s cubic-bezier(.4,0,.2,1);width:28px}[data-theme=dark] .toggle-thumb{background:#f8fafc;border-color:#f8fafccc;transform:translateX(33px)}.toggle-icon{color:#667eea;font-size:14px;transition:all .3s ease}[data-theme=dark] .toggle-icon{color:#f093fb}.theme-toggle:hover .toggle-track{box-shadow:0 6px 20px #667eea66;transform:scale(1.08)}[data-theme=dark] .theme-toggle:hover .toggle-track{box-shadow:0 6px 20px #f093fb66}.theme-toggle:active .toggle-track{transform:scale(.95)}.theme-toggle:focus{outline:none}.theme-toggle:focus .toggle-track{border-color:var(--accent-color);box-shadow:0 0 0 3px #667eea1a}@media (max-width:768px){.toggle-track{height:28px;width:55px}.toggle-thumb{height:24px;width:24px}[data-theme=dark] .toggle-thumb{transform:translateX(27px)}.toggle-icon{font-size:12px}}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--card-bg);border-bottom:1px solid var(--border-color);box-shadow:0 2px 12px var(--shadow-color);color:var(--text-primary);overflow:hidden;padding:1.5rem 0;position:relative}.header:before{background:radial-gradient(circle at 20% 80%,#667eea05 0,#0000 50%),radial-gradient(circle at 80% 20%,#764ba205 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.header-content{align-items:center;display:flex;gap:1.5rem;justify-content:space-between;min-height:80px;position:relative;z-index:1}.restaurant-info{flex:1 1}.restaurant-name{color:var(--text-primary);cursor:pointer;font-size:2.5rem;font-weight:800;letter-spacing:1px;margin-bottom:.3rem;position:relative;text-shadow:0 1px 3px var(--shadow-color);text-transform:uppercase;transition:all .3s ease}.restaurant-name:hover{text-shadow:0 2px 6px var(--shadow-color);transform:scale(1.01)}.restaurant-name:after{background:var(--gradient-primary);border-radius:1px;bottom:-4px;box-shadow:0 1px 4px #667eea33;content:"";height:2px;left:0;position:absolute;transform:scaleX(0);transition:transform .3s ease;width:100%}.restaurant-name:hover:after{transform:scaleX(1)}.restaurant-description{color:var(--text-secondary);font-size:1rem;font-weight:400;line-height:1.5;max-width:500px;position:relative}.theme-toggle{position:relative;z-index:2}@media (max-width:768px){.header-content{flex-direction:column;gap:1rem;text-align:center}.restaurant-name{font-size:2rem;letter-spacing:.5px}.restaurant-description{font-size:.9rem}.restaurant-description:before{display:none}}@media (max-width:480px){.restaurant-name{font-size:1.6rem;letter-spacing:.3px}.restaurant-description{font-size:.85rem}}.category-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--card-bg);border-bottom:1px solid var(--border-color);box-shadow:0 2px 12px var(--shadow-color);position:-webkit-sticky;position:sticky;top:0;z-index:100}.tabs-container{-ms-overflow-style:none;display:flex;gap:.5rem;overflow-x:auto;padding:1rem 0;scrollbar-width:none}.tabs-container::-webkit-scrollbar{display:none}.tab{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid #0000;border-radius:25px;box-shadow:0 1px 4px var(--shadow-color);color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;min-width:-webkit-fit-content;min-width:fit-content;padding:.75rem 1.25rem;transition:all .2s ease;white-space:nowrap}.tab,.tab:hover{background:var(--bg-secondary)}.tab:hover{border-color:var(--accent-color);box-shadow:0 2px 8px var(--shadow-color);color:var(--text-primary)}.tab.active{background:var(--gradient-primary);border-color:#0000;box-shadow:0 2px 10px #667eea4d;color:#fff}.tab-icon{font-size:1.1rem}.tab-name{font-weight:500;letter-spacing:.3px}@media (max-width:768px){.category-tabs{padding:0 1rem}.tabs-container{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;gap:.4rem;padding:.75rem 0;scroll-snap-type:x mandatory;scrollbar-width:none}.tabs-container::-webkit-scrollbar{display:none}.tab{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;box-shadow:var(--card-shadow);flex-shrink:0;font-size:.85rem;padding:.6rem 1rem;scroll-snap-align:start}.tab:hover{background:var(--border-color);box-shadow:0 2px 8px var(--shadow-color)}.tab.active{background:var(--gradient-primary);box-shadow:0 2px 10px #667eea4d;color:#fff}.tab-icon{font-size:1rem}.tab-name{font-weight:500}}.image-fallback{align-items:center;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:8px;color:var(--text-secondary);display:flex;height:200px;justify-content:center;width:100%}.fallback-content{align-items:center;display:flex;flex-direction:column;gap:.5rem}.fallback-icon{font-size:2rem;opacity:.6}.fallback-text{font-size:.9rem;font-weight:500;text-align:center}img.loading{opacity:.7;transition:opacity .3s ease}.menu-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative;transition:all .3s ease}.menu-item:hover{border-color:var(--accent-color);box-shadow:0 8px 20px var(--shadow-color);transform:translateY(-4px)}.menu-item:before{background:var(--gradient-primary);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.menu-item:hover:before{transform:scaleX(1)}.menu-item.unavailable{filter:grayscale(.5);opacity:.6}.menu-item.unavailable:hover{box-shadow:var(--card-shadow);transform:none}.menu-item-image{background:var(--bg-secondary);height:180px;overflow:hidden;position:relative;width:100%}.menu-item-image img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.menu-item:hover .menu-item-image img{transform:scale(1.05)}.unavailable-overlay{align-items:center;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#000000b3;bottom:0;color:#fff;display:flex;font-size:1rem;font-weight:600;justify-content:center;left:0;letter-spacing:.5px;position:absolute;right:0;text-transform:uppercase;top:0}.menu-item-content{display:flex;flex:1 1;flex-direction:column;padding:1.25rem;position:relative}.menu-item-header{align-items:flex-start;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:.75rem}.menu-item-name{color:var(--text-primary);flex:1 1;font-size:1.1rem;font-weight:600;letter-spacing:.3px;line-height:1.3;margin:0}.menu-item-price{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-size:1.2rem;font-weight:700;position:relative;white-space:nowrap}.menu-item-price:after{-webkit-text-fill-color:var(--text-primary);font-weight:500}.menu-item-description{color:var(--text-secondary);flex:1 1;font-size:.9rem;font-weight:400;line-height:1.5;margin:0}.menu-item-badge{background:var(--gradient-secondary);border-radius:12px;box-shadow:0 1px 4px #f093fb33;color:#fff;font-size:.75rem;font-weight:500;letter-spacing:.3px;padding:.2rem .6rem;position:absolute;right:.75rem;text-transform:uppercase;top:.75rem}@media (max-width:768px){.menu-item{border-radius:10px}.menu-item:hover{transform:translateY(-2px)}.menu-item-content{padding:1rem}.menu-item-name{font-size:1rem}.menu-item-price{font-size:1.1rem}.menu-item-description{font-size:.85rem}.menu-item-image{height:150px}}.menu-grid-section{margin-bottom:2rem;padding-top:1rem}.grid-title{color:var(--text-primary);font-size:1.3rem;font-weight:600;margin-bottom:.8rem;position:relative;text-align:center}.grid-title:after{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:1px;bottom:-3px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);width:40px}.menu-grid{grid-gap:1rem;display:grid;gap:1rem;padding:.5rem}@media (min-width:769px){.menu-grid{gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));padding:1rem}}@media (max-width:768px){.menu-grid-section{margin-bottom:1rem;padding-top:.3rem}.grid-title{font-size:1.1rem;margin-bottom:.6rem}.menu-grid{gap:.8rem;grid-template-columns:1fr;padding:.3rem}}@media (min-width:769px) and (max-width:1024px){.menu-grid{gap:1.2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));padding:.8rem}}.menu-grid>*{animation:fadeInUp .5s ease-out;animation-fill-mode:both}.menu-grid>:first-child{animation-delay:.1s}.menu-grid>:nth-child(2){animation-delay:.2s}.menu-grid>:nth-child(3){animation-delay:.3s}.menu-grid>:nth-child(4){animation-delay:.4s}.menu-grid>:nth-child(5){animation-delay:.5s}.menu-grid>:nth-child(6){animation-delay:.6s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (hover:none) and (pointer:coarse){.menu-grid{gap:1rem}}.subcategory-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);border-radius:12px;box-shadow:var(--card-shadow);margin:auto;position:-webkit-sticky;position:sticky;top:0;z-index:90}.subcategory-tabs-container{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;display:flex;gap:.5rem;overflow-x:auto;padding:.75rem 1rem;scroll-snap-type:x mandatory;scrollbar-width:none}.subcategory-tabs-container::-webkit-scrollbar{display:none}.subcategory-tab{align-items:center;background:var(--bg-secondary);border:none;border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--card-shadow);color:var(--text-secondary);cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;font-size:.9rem;gap:.25rem;min-width:-webkit-fit-content;min-width:fit-content;padding:.75rem 1rem;scroll-snap-align:start;transition:all .2s ease;white-space:nowrap}.subcategory-tab:hover{background:var(--border-color);box-shadow:0 2px 8px var(--shadow-color)}.subcategory-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 2px 10px #667eea66;color:#fff}.subcategory-tab-name{font-size:.85rem;font-weight:600}.subcategory-tab-count{font-size:.75rem;font-weight:500;opacity:.8}.subcategory-tab.active .subcategory-tab-count{opacity:.9}@media (max-width:480px){.subcategory-tabs-container{gap:.4rem;padding:.5rem .75rem}.subcategory-tab{font-size:.8rem;padding:.6rem .8rem}.subcategory-tab-name{font-size:.8rem}.subcategory-tab-count{font-size:.7rem}}.subcategory-tab{animation:slideIn .3s ease-out}@media (hover:none) and (pointer:coarse){.subcategory-tab{min-height:44px;min-width:80px}}.subcategory-section{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;margin-bottom:2rem;overflow:hidden;padding:1.5rem}.subcategory-section,.subcategory-title{box-shadow:var(--card-shadow);position:relative}.subcategory-title{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);display:inline-block;font-size:1.5rem;font-weight:700;letter-spacing:.5px;margin:0 0 1.5rem;padding:1rem 1.5rem;text-transform:uppercase}.subcategory-title:after{border-radius:1px;bottom:-2px;box-shadow:0 1px 4px #667eea33;height:2px;left:1.5rem;width:60px}.subcategory-title:after,.subcategory-title:before{background:var(--gradient-primary);content:"";position:absolute}.subcategory-title:before{border-radius:1.5px;height:24px;left:-10px;opacity:.6;top:50%;transform:translateY(-50%);width:3px}[data-theme=dark] .subcategory-title{color:#fff}.desktop-view{display:block}.mobile-view{display:none}.desktop-subcategory{margin-bottom:2rem}.desktop-subcategory:last-child{margin-bottom:0}.desktop-subcategory-title{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;box-shadow:var(--card-shadow);color:var(--text-primary);display:inline-block;font-weight:600;letter-spacing:.3px;margin-bottom:1.5rem;padding:.75rem 1.25rem;position:relative;transition:all .3s ease}.desktop-subcategory-title:hover{box-shadow:0 3px 12px var(--shadow-color);transform:translateX(5px)}.desktop-subcategory-title:after{background:var(--gradient-primary);border-radius:1px;bottom:-2px;content:"";height:2px;left:1.25rem;position:absolute;transition:width .3s ease;width:0}.desktop-subcategory-title:hover:after{width:90%}@media (max-width:768px){.subcategory-section{border-radius:10px;margin-bottom:1.5rem;padding:1rem}.desktop-view,.subcategory-title{display:none}.mobile-view{display:block}.desktop-subcategory{margin-bottom:1.5rem}.desktop-subcategory-title{font-size:1.1rem;padding:.6rem 1rem}.mobile-view .carousel-container{touch-action:pan-y pinch-zoom;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.mobile-view .carousel-wrapper{touch-action:pan-y pinch-zoom}.mobile-view .carousel-track{will-change:transform}.mobile-view .carousel-wrapper:active{cursor:grabbing}.mobile-view .carousel-wrapper:active .carousel-track{transition:none}.mobile-view .carousel-button{display:none}.mobile-view .carousel-dots{padding:.8rem}.mobile-view .carousel-dot{height:8px;margin:0 .3rem;width:8px}}@media (max-width:480px){.subcategory-section{margin-bottom:1rem;padding:.75rem}.subcategory-title{display:none}.desktop-subcategory-title{font-size:1rem;padding:.5rem .75rem}.mobile-view .carousel-dots{padding:.6rem}.mobile-view .carousel-dot{height:6px;margin:0 .2rem;width:6px}.mobile-view .carousel-wrapper{min-height:200px}}.login-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.login-container{background:var(--bg-color);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 20px 40px #0000004d;max-width:400px;padding:2rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-header h2{color:var(--text-color);font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.login-header p{color:var(--text-secondary);font-size:.9rem;margin:0}.login-form{display:flex;flex-direction:column;gap:1.5rem}.password-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1.2rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:color .2s ease}.password-toggle:hover:not(:disabled){color:var(--text-color)}.password-toggle:disabled{cursor:not-allowed;opacity:.6}.login-actions{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.login-button{align-items:center;background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem;transition:all .2s ease}.login-button:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.cancel-button{background:#0000;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:.75rem;transition:all .2s ease}.cancel-button:hover:not(:disabled){background:var(--hover-bg);color:var(--text-color)}.cancel-button:disabled{cursor:not-allowed;opacity:.6}.login-footer{border-top:1px solid var(--border-color);margin-top:2rem;padding-top:1.5rem;text-align:center}.login-footer p{color:var(--text-secondary);font-size:.9rem;margin:0 0 1rem}.register-link{background:#0000;border:1px solid var(--primary-color);border-radius:6px;color:var(--primary-color);cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s ease}.register-link:hover:not(:disabled){background:var(--primary-color);color:#fff}.register-link:disabled{cursor:not-allowed;opacity:.6}@media (max-width:480px){.login-container{margin:1rem;padding:1.5rem}.login-header h2{font-size:1.25rem}.cancel-button,.form-group input,.login-button{padding:.625rem}}.register-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.register-container{background:var(--bg-color);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 20px 40px #0000004d;max-width:400px;padding:2rem;width:100%}.register-header{margin-bottom:2rem;text-align:center}.register-header h2{color:var(--text-color);font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.register-header p{color:var(--text-secondary);font-size:.9rem;margin:0}.register-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{color:var(--text-color);font-weight:500}.form-group input{background:var(--input-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-color);font-size:1rem;padding:.75rem;transition:all .2s ease}.form-group input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.1);outline:none}.form-group input:disabled{cursor:not-allowed;opacity:.6}.code-input{font-family:Courier New,monospace;font-size:1.1rem;font-weight:600;letter-spacing:2px;text-align:center;text-transform:uppercase}.error-message{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#ef4444;font-size:.9rem;padding:.75rem;text-align:center}.register-actions{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.register-button{align-items:center;background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem;transition:all .2s ease}.register-button:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.register-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.back-button{background:#0000;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:1rem;padding:.75rem;transition:all .2s ease}.back-button:hover:not(:disabled){background:var(--hover-bg);color:var(--text-color)}.back-button:disabled{cursor:not-allowed;opacity:.6}.loading-spinner{border:2px solid #0000;border-top-color:currentcolor;height:16px;width:16px}@media (max-width:480px){.register-container{margin:1rem;padding:1.5rem}.register-header h2{font-size:1.25rem}.back-button,.form-group input,.register-button{padding:.625rem}}.admin-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;bottom:20px;box-shadow:0 4px 20px #667eea66;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:60px;justify-content:center;position:fixed;right:20px;transition:all .3s ease;width:60px;z-index:1000}.admin-button:hover{box-shadow:0 6px 30px #667eea99;transform:scale(1.1)}.admin-button:active{transform:scale(.95)}.admin-button:focus{box-shadow:0 4px 20px #667eea66,0 0 0 3px #667eea4d;outline:none}.valerka-hint{align-items:center;animation:valerkaPulse 2s ease-in-out infinite;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:25px;box-shadow:0 4px 15px #0000001a;display:flex;gap:.5rem;padding:.75rem 1rem}.valerka-text{color:#333;font-size:.9rem;font-weight:600;white-space:nowrap}.valerka-arrow{animation:arrowBounce 1s ease-in-out infinite;color:#667eea;font-size:1.2rem}@keyframes valerkaPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}@keyframes arrowBounce{0%,to{transform:translateX(0)}50%{transform:translateX(3px)}}@media (max-width:768px){.admin-button-container{bottom:1.5rem;gap:.75rem;right:1.5rem}.admin-button{font-size:1.3rem;height:50px;width:50px}.valerka-hint{padding:.6rem .8rem}.valerka-text{font-size:.8rem}.valerka-arrow{font-size:1rem}}.app{background:var(--bg-primary);background-attachment:fixed;background-image:radial-gradient(circle at 20% 80%,#667eea08 0,#0000 50%),radial-gradient(circle at 80% 20%,#764ba208 0,#0000 50%),radial-gradient(circle at 40% 40%,#667eea05 0,#0000 50%);background-position:50%;background-size:cover;min-height:100vh;position:relative;transition:background-color .3s ease}.loading-screen{background:var(--bg-primary);color:var(--text-primary)}.loading-spinner{border-top:4px solid var(--border-color);border:4px solid var(--border-color);height:50px;width:50px}.error-screen{background:var(--bg-primary);color:var(--text-primary)}.error-screen h2{color:#e74c3c;margin-bottom:1rem}.error-screen button{font-weight:600;margin-top:1rem;transition:all .3s ease}.error-screen button:hover{transform:translateY(-2px)}.app:before{background:linear-gradient(135deg,#667eea05,#0000 50%),linear-gradient(45deg,#0000,#764ba205);bottom:0;content:"";left:0;pointer-events:none;position:fixed;right:0;top:0;z-index:-1}html{scroll-behavior:smooth}.menu-content{padding:2rem 0;position:relative;z-index:1}.empty-state{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;color:var(--text-secondary);font-size:1.1rem;margin:2rem 0;padding:3rem 1rem}.emoji-picker-container{display:inline-block;position:relative}.emoji-display{align-items:center;display:flex;gap:8px}.emoji-button{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;font-size:1.2rem;min-width:50px;padding:8px 12px;text-align:center;transition:all .2s ease}.emoji-button:hover{background:var(--border-color);box-shadow:0 2px 8px var(--shadow-color)}.suggested-emoji-button{background:linear-gradient(135deg,#667eea,#764ba2);border:1px solid #0000;border-radius:8px;color:#fff;cursor:pointer;font-size:1.2rem;min-width:50px;padding:8px 12px;position:relative;text-align:center;transition:all .2s ease}.suggested-emoji-button:hover{box-shadow:0 4px 12px #667eea4d;transform:scale(1.05)}.suggested-emoji-button:before{align-items:center;background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;content:"💡";display:flex;font-size:.8rem;height:16px;justify-content:center;position:absolute;right:-8px;top:-8px;width:16px}.emoji-picker{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 32px var(--shadow-color);left:0;margin-top:8px;max-width:400px;min-width:300px;position:absolute;right:0;top:100%;z-index:1000}.emoji-picker-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);border-radius:12px 12px 0 0;display:flex}.tab-button{background:#0000;color:var(--text-secondary);font-size:.85rem;font-weight:500;padding:10px 8px;transition:all .2s ease}.tab-button:hover{background:var(--border-color);color:var(--text-primary)}.tab-button.active{background:var(--accent-color);color:#fff}.emoji-picker-content{max-height:300px;overflow-y:auto;padding:12px}.emoji-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(8,1fr)}.emoji-item{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;font-size:1.2rem;justify-content:center;min-height:40px;padding:8px;transition:all .2s ease}.emoji-item:hover{background:var(--border-color);box-shadow:0 2px 8px var(--shadow-color);transform:scale(1.1)}.emoji-item.suggested{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;color:#fff;position:relative}.emoji-item.suggested:after{align-items:center;background:#fff;border-radius:50%;content:"💡";display:flex;font-size:.7rem;height:12px;justify-content:center;position:absolute;right:-4px;top:-4px;width:12px}.emoji-categories{display:flex;flex-direction:column;gap:16px}.emoji-category{border-bottom:1px solid var(--border-color);padding-bottom:12px}.emoji-category:last-child{border-bottom:none;padding-bottom:0}.category-title{color:var(--text-primary);font-size:.9rem;font-weight:600;margin:0 0 8px;padding:0 4px}.emoji-picker-footer{background:var(--bg-secondary);border-radius:0 0 12px 12px;border-top:1px solid var(--border-color);padding:12px;text-align:center}.close-button{background:var(--accent-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .2s ease}.close-button:hover{background:var(--accent-hover);transform:translateY(-1px)}@media (max-width:768px){.emoji-picker{left:50%;margin:0;max-height:80vh;max-width:350px;position:fixed;top:50%;transform:translate(-50%,-50%);width:90vw}.emoji-grid{gap:6px;grid-template-columns:repeat(6,1fr)}.emoji-item{font-size:1.1rem;min-height:35px;padding:6px}.tab-button{font-size:.8rem;padding:8px 6px}}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.emoji-picker{animation:slideIn .2s ease-out}.admin-panel{background:linear-gradient(135deg,#667eea,#764ba2);color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh}.admin-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #fff3;box-shadow:0 2px 20px #0000001a;padding:1rem 0}.admin-header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 2rem}.admin-title h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:700;margin:0}.admin-title p{color:#666;font-size:.9rem;margin:.25rem 0 0}.logout-button{align-items:center;background:linear-gradient(135deg,#ff6b6b,#ee5a24);border:none;border-radius:12px;box-shadow:0 4px 15px #ff6b6b4d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.logout-button:hover{box-shadow:0 6px 20px #ff6b6b66;transform:translateY(-2px)}.reset-button{align-items:center;background:linear-gradient(135deg,#f39c12,#e67e22);border:none;border-radius:12px;box-shadow:0 4px 15px #f39c124d;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;margin-right:1rem;padding:.75rem 1.5rem;transition:all .3s ease}.reset-button:hover{box-shadow:0 6px 20px #f39c1266;transform:translateY(-2px)}.admin-content{display:flex;gap:2rem;margin:0 auto;max-width:1400px;min-height:calc(100vh - 100px);padding:2rem}.admin-sidebar{flex-shrink:0;width:320px}.sidebar-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:12px;display:flex;margin-bottom:1.5rem;padding:.25rem}.tab-button{background:none;border:none;border-radius:8px;color:#fffc;cursor:pointer;flex:1 1;font-weight:600;padding:.75rem 1rem;transition:all .3s ease}.tab-button.active{background:#ffffffe6;box-shadow:0 2px 10px #0000001a;color:#333}.tab-button:hover:not(.active){background:#ffffff1a;color:#fff}.sidebar-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;padding:1.5rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.section-header h3{color:#333;font-size:1.2rem;font-weight:700;margin:0}.add-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .3s ease}.add-button:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.add-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.category-selector{margin-bottom:1.5rem}.category-selector label{color:#333;display:block;font-weight:600;margin-bottom:.5rem}.category-select{background:#fff;border:2px solid #e1e5e9;border-radius:8px;font-size:.9rem;padding:.75rem;transition:all .3s ease;width:100%}.category-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.category-list{display:flex;flex-direction:column;gap:.75rem}.category-item{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;display:flex;justify-content:space-between;padding:1rem;transition:all .3s ease}.category-item:hover{background:#e9ecef;transform:translateX(4px)}.category-info{flex:1 1;gap:.75rem}.category-icon,.category-info{align-items:center;display:flex}.category-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;font-size:1.5rem;height:40px;justify-content:center;width:40px}.category-details{flex:1 1}.category-name{color:#333;display:block;font-weight:600;margin-bottom:.25rem}.item-count{background:#e9ecef;border-radius:12px;color:#666;font-size:.8rem;padding:.2rem .5rem}.category-actions{display:flex;gap:.5rem}.action-button{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s ease}.action-button.edit{color:#28a745}.action-button.edit:hover{background:#28a7451a}.action-button.delete{color:#dc3545}.action-button.delete:hover{background:#dc35451a}.action-button.move{background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;padding:4px;transition:all .2s ease}.action-button.move:hover:not(:disabled){background-color:#007bff;color:#fff}.action-button.move:disabled{color:#dee2e6;cursor:not-allowed}.checkbox-label{align-items:center;color:#495057;cursor:pointer;display:flex;font-weight:500;gap:8px}.checkbox-label input[type=checkbox]{accent-color:#007bff;cursor:pointer;height:18px;width:18px}.checkbox-label:hover{color:#007bff}.image-upload-container{display:flex;flex-direction:column;gap:10px}.file-input{display:none}.upload-button{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .2s ease;width:-webkit-fit-content;width:fit-content}.upload-button:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.upload-button:disabled{background:#6c757d;cursor:not-allowed;transform:none}.upload-progress{border-radius:4px;font-size:14px;font-weight:500;padding:8px 12px}.upload-progress.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.upload-progress.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.current-image{display:inline-block;margin-top:10px;position:relative}.preview-image{border:2px solid #e9ecef;border-radius:8px;max-height:150px;max-width:150px;object-fit:cover}.remove-image-btn{align-items:center;background:#dc3545;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:24px;justify-content:center;line-height:1;position:absolute;right:-8px;top:-8px;transition:all .2s ease;width:24px}.remove-image-btn:hover{background:#c82333;transform:scale(1.1)}.image-url-input{border-top:1px solid #e9ecef;margin-top:15px;padding-top:15px}.image-url-input label{color:#6c757d;display:block;font-size:14px;font-weight:500;margin-bottom:5px}.admin-main{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:16px;box-shadow:0 8px 32px #0000001a;flex:1 1;padding:2rem}.main-header{align-items:center;border-bottom:2px solid #f1f3f4;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.main-header h2{color:#333;font-size:1.8rem;font-weight:700;margin:0}.categories-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.category-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:16px;padding:1.5rem;transition:all .3s ease}.category-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-4px)}.category-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.category-card-title{align-items:center;display:flex;gap:.75rem}.category-card-title h3{color:#333;font-size:1.3rem;font-weight:700;margin:0}.add-subcategory-button{align-items:center;background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;box-shadow:0 4px 15px #28a7454d;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .3s ease}.add-subcategory-button:hover{box-shadow:0 6px 20px #28a74566;transform:scale(1.1)}.subcategories-list{display:flex;flex-direction:column;gap:.75rem}.subcategory-item{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:12px;display:flex;justify-content:space-between;padding:1rem;transition:all .3s ease}.subcategory-item:hover{background:#f8f9fa;transform:translateX(4px)}.subcategory-info h4{color:#333;font-size:1rem;font-weight:600;margin:0 0 .25rem}.subcategory-actions{display:flex;gap:.5rem}.items-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.item-card{background:#fff;border:1px solid #e9ecef;border-radius:16px;overflow:hidden;position:relative;transition:all .3s ease}.item-card:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-4px)}.item-image{align-items:center;background:#f8f9fa;display:flex;height:200px;justify-content:center;overflow:hidden}.item-image img{height:100%;object-fit:cover;width:100%}.item-image-placeholder{align-items:center;color:#adb5bd;display:flex;height:100%;justify-content:center}.item-content{padding:1.5rem}.item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.item-header h4{color:#333;flex:1 1;margin:0}.item-header h4,.item-price{font-size:1.1rem;font-weight:700}.item-price{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#667eea}.item-description{color:#666;font-size:.9rem;line-height:1.5;margin:0 0 1rem}.item-categories{display:flex;gap:.5rem;margin-bottom:1rem}.category-badge,.subcategory-badge{border-radius:20px;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.category-badge{background:#667eea1a;color:#667eea}.subcategory-badge{background:#764ba21a;color:#764ba2}.item-actions{display:flex;gap:.5rem;justify-content:flex-end}.empty-state{color:#666;padding:2rem;text-align:center}.empty-state p{font-style:italic;margin:0}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h3{color:#333;font-size:1.3rem;font-weight:700;margin:0}.modal-close{background:none;border:none;border-radius:8px;color:#666;cursor:pointer;font-size:1.5rem;padding:.5rem;transition:all .2s ease}.modal-close:hover{background:#f8f9fa;color:#333}.modal-body{padding:1.5rem}.form{gap:1.5rem}.form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{font-size:.9rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e1e5e9;border-radius:8px;font-size:.9rem;padding:.75rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{font-family:inherit;min-height:80px;resize:vertical}.form-group select{cursor:pointer}.form-group select:disabled{background:#f8f9fa;cursor:not-allowed;opacity:.6}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn-primary{border:none;border-radius:8px;box-shadow:0 4px 15px #667eea4d;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-primary:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-secondary{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;color:#666;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-secondary:hover{background:#e9ecef;color:#333}@media (max-width:1024px){.admin-content{flex-direction:column;padding:1rem}.admin-sidebar{width:100%}.categories-grid{grid-template-columns:1fr}.items-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media (max-width:768px){.admin-header-content{flex-direction:column;gap:1rem;text-align:center}.main-header{align-items:flex-start;flex-direction:column;gap:1rem}.items-grid{grid-template-columns:1fr}.category-card-header{align-items:flex-start;flex-direction:column;gap:1rem}.form-actions{flex-direction:column}.modal-content{margin:1rem;width:95%}}.admin-loading,.admin-page{background:var(--bg-color);min-height:100vh}.admin-loading{align-items:center;color:var(--text-color);display:flex;flex-direction:column;justify-content:center}.admin-loading .loading-spinner{animation:spin 1s linear infinite;border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:40px;margin-bottom:1rem;width:40px}.admin-loading p{color:var(--text-secondary);font-size:1.1rem}.admin-error{align-items:center;background:var(--bg-color);color:var(--text-color);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.admin-error h2{color:#ef4444;font-size:1.5rem;margin:0 0 1rem}.admin-error p{color:var(--text-secondary);font-size:1rem;margin:0 0 2rem;max-width:400px}.admin-error button{background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.admin-error button:hover{background:var(--primary-hover);transform:translateY(-1px)}:root{--bg-color:#fff;--bg-primary:#fff;--bg-secondary:#f8fafc;--input-bg:#f8fafc;--text-color:#000;--text-primary:#000;--text-secondary:#64748b;--border-color:#e2e8f0;--shadow-color:#0000000f;--card-bg:#fffffff2;--card-shadow:0 1px 8px #0000000f;--gradient-primary:linear-gradient(135deg,#667eea,#764ba2);--gradient-secondary:linear-gradient(135deg,#f093fb,#f5576c);--primary-color:#667eea;--primary-hover:#5a67d8;--primary-rgb:102,126,234;--accent-color:#667eea;--accent-hover:#5a67d8;--hover-bg:#f1f5f9}[data-theme=dark]{--bg-color:#0a0e17;--bg-primary:#0a0e17;--bg-secondary:#1a1f2e;--input-bg:#1a1f2e;--text-color:#fff;--text-primary:#fff;--text-secondary:#94a3b8;--border-color:#334155;--shadow-color:#0006;--card-bg:#1e293bf2;--card-shadow:0 2px 8px #0006;--gradient-primary:linear-gradient(135deg,#667eea,#764ba2);--gradient-secondary:linear-gradient(135deg,#f093fb,#f5576c);--primary-color:#8b5cf6;--primary-hover:#a78bfa;--primary-rgb:139,92,246;--accent-color:#8b5cf6;--accent-hover:#a78bfa;--hover-bg:#1e293b}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;background-color:var(--bg-color);color:#000;color:var(--text-color);font-family:Montserrat,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:14px;line-height:1.5;overflow-x:hidden;transition:background-color .3s ease,color .3s ease}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{background-color:initial;margin:0 auto;max-width:1200px;padding:0 20px;position:relative;transition:background-color .3s ease;z-index:1}.btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);background:var(--gradient-primary);box-shadow:0 2px 8px #667eea33;color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.btn-secondary{background-color:#f8fafc;background-color:var(--bg-secondary);border:1px solid #e2e8f0;border:1px solid var(--border-color);color:#000;color:var(--text-color)}.btn-secondary:hover{background-color:#e2e8f0;background-color:var(--border-color)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f8fafc;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#e2e8f0;background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#64748b;background:var(--text-secondary)}.loading-screen{align-items:center;background:#fff;background:var(--bg-color);color:#000;color:var(--text-color);display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-top:3px solid #667eea;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:40px;margin-bottom:1rem;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-screen{align-items:center;background:#fff;background:var(--bg-color);color:#000;color:var(--text-color);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.error-screen h2{color:#ef4444;font-size:1.5rem;margin:0 0 1rem}.error-screen p{color:#64748b;color:var(--text-secondary);font-size:1rem;margin:0 0 2rem;max-width:400px}.error-screen button{background:#667eea;background:var(--primary-color);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.error-screen button:hover{background:#5a67d8;background:var(--primary-hover);transform:translateY(-1px)}