*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root,.theme-light{--bg: #f1f5f9;--bg2: #ffffff;--bg3: #f8fafc;--border: #e2e8f0;--border-hover: #cbd5e1;--accent: #f59e0b;--accent-hover: #d97706;--accent-light: rgba(245,158,11,.1);--text: #0f172a;--text2: #475569;--text3: #94a3b8;--danger: #ef4444;--danger-light: rgba(239,68,68,.08);--danger-hover: rgba(239,68,68,.15);--success: #22c55e;--success-light: rgba(34,197,94,.1);--info: #3b82f6;--info-light: rgba(59,130,246,.1);--card-bg: #ffffff;--card-hover: #f8fafc;--input-bg: #ffffff;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);--overlay: rgba(0,0,0,.4);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--transition: .2s ease}.theme-dark{--bg: #0f1117;--bg2: #161b27;--bg3: #1e2536;--border: #2a3148;--border-hover: #3a4560;--accent: #f59e0b;--accent-hover: #fbbf24;--accent-light: rgba(245,158,11,.12);--text: #e2e8f0;--text2: #94a3b8;--text3: #64748b;--danger: #ef4444;--danger-light: rgba(239,68,68,.1);--danger-hover: rgba(239,68,68,.2);--success: #22c55e;--success-light: rgba(34,197,94,.12);--info: #3b82f6;--info-light: rgba(59,130,246,.12);--card-bg: #161b27;--card-hover: #1e2536;--input-bg: #161b27;--shadow-sm: 0 1px 3px rgba(0,0,0,.3);--shadow-md: 0 4px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.5);--overlay: rgba(0,0,0,.6)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;transition:background .3s,color .3s;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text2)}.sidebar{background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:width .25s cubic-bezier(.4,0,.2,1);overflow:hidden;flex-shrink:0}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:20px 16px;border-bottom:1px solid var(--border);min-height:72px;overflow:hidden}.sidebar-logo-icon{width:38px;height:38px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,var(--accent),var(--accent-hover));display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:0 4px 12px #f59e0b4d}.sidebar-logo-text{overflow:hidden}.sidebar-logo-title{font-weight:700;font-size:14px;white-space:nowrap}.sidebar-logo-sub{font-size:11px;color:var(--text3);white-space:nowrap}.sidebar-nav{flex:1;padding:12px 8px;overflow:hidden}.sidebar-nav-item{width:100%;display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;border:none;cursor:pointer;background:transparent;color:var(--text2);transition:all var(--transition);text-align:left;margin-bottom:4px;border-left:3px solid transparent;overflow:hidden;white-space:nowrap;font-family:inherit;font-size:14px}.sidebar-nav-item:hover{background:var(--bg3)}.sidebar-nav-item.active{background:var(--accent-light);color:var(--accent);border-left-color:var(--accent);font-weight:600}.sidebar-nav-icon{font-size:18px;flex-shrink:0;display:flex;align-items:center}.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px}.sidebar-footer-btn{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;border:none;cursor:pointer;background:transparent;color:var(--text3);transition:background var(--transition);overflow:hidden;white-space:nowrap;font-family:inherit;font-size:13px}.sidebar-footer-btn:hover{background:var(--bg3)}.sidebar-footer-btn.danger{color:var(--danger)}.sidebar-footer-btn.danger:hover{background:var(--danger-light)}.topbar{padding:0 28px;height:64px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg2);flex-shrink:0;transition:background .3s,border-color .3s}.topbar-title{font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}.topbar-actions{display:flex;gap:12px;align-items:center}.btn{padding:8px 16px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;transition:all var(--transition);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#000;box-shadow:0 2px 8px #f59e0b40}.btn-primary:hover{box-shadow:0 4px 16px #f59e0b59}.btn-secondary{background:var(--info);color:#fff;box-shadow:0 2px 8px #3b82f640}.btn-secondary:hover{box-shadow:0 4px 12px #3b82f659}.btn-success{background:var(--success);color:#fff;box-shadow:0 2px 8px #22c55e40}.btn-success:hover{box-shadow:0 4px 12px #22c55e59}.btn-danger-outline{background:transparent;border:1px solid var(--danger);color:var(--danger)}.btn-danger-outline:hover{background:var(--danger-light)}.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg3);border-color:var(--border-hover)}.btn-icon{padding:6px;border-radius:6px;border:none;background:transparent;color:var(--text3);cursor:pointer;transition:all var(--transition);display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--bg3);color:var(--text)}.btn-icon.danger:hover{background:var(--danger-light);color:var(--danger)}.btn-sm{padding:5px 10px;font-size:11px;border-radius:6px}.card{background:var(--card-bg);border-radius:var(--radius-md);border:1px solid var(--border);padding:24px;transition:all var(--transition)}.card-hover:hover{box-shadow:var(--shadow-md);border-color:var(--border-hover)}.card-header{font-size:14px;font-weight:700;color:var(--text2);letter-spacing:.5px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.input,textarea,select{font-family:inherit;background:var(--input-bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;width:100%;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.input-error{border-color:var(--danger)!important;box-shadow:0 0 0 3px var(--danger-light)!important}.form-label{display:block;font-size:12px;color:var(--text2);font-weight:600;margin-bottom:6px;letter-spacing:.4px}.form-group{margin-bottom:20px}.form-error{color:var(--danger);font-size:13px;margin-top:6px}.form-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text);font-weight:500}.form-checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.search-wrapper{position:relative;margin-bottom:16px}.search-wrapper .search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}.search-wrapper .search-input{padding-left:42px}.search-wrapper .search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text3);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center}.search-wrapper .search-clear:hover{background:var(--bg3);color:var(--text)}.category-header{display:flex;align-items:center;gap:10px;cursor:pointer;padding:12px 16px;background:var(--bg2);border-radius:var(--radius-sm);border:1px solid var(--border);font-weight:600;font-size:14px;-webkit-user-select:none;user-select:none;transition:all var(--transition)}.category-header:hover{border-color:var(--border-hover)}.category-chevron{transition:transform .2s ease;display:flex;align-items:center;color:var(--text3)}.category-chevron.open{transform:rotate(90deg)}.category-count{margin-left:auto;font-size:12px;color:var(--text3);background:var(--bg3);padding:2px 8px;border-radius:10px;font-weight:500}.dish-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--card-bg);border-radius:var(--radius-sm);border:1px solid var(--border);border-left:3px solid var(--info);transition:all var(--transition)}.dish-item:hover{box-shadow:var(--shadow-sm);border-color:var(--border-hover);transform:translateY(-1px)}.dish-info{display:flex;align-items:center;gap:12px}.dish-thumb{width:50px;height:50px;object-fit:cover;border-radius:6px;background:var(--bg3)}.dish-name{font-weight:600;font-size:14px}.dish-meta{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:8px;margin-top:2px}.dish-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--text3)}.dish-badge-special{color:var(--accent);font-weight:600}.dish-badge-hidden{color:var(--danger)}.dish-actions{display:flex;gap:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease}.modal{background:var(--card-bg);border-radius:var(--radius-lg);width:95%;max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg);animation:modalIn .25s ease;border:1px solid var(--border)}.modal-sm{max-width:500px}.modal-md{max-width:700px}.modal-lg{max-width:900px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:18px;font-weight:700}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text3);padding:4px 8px;border-radius:6px;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--bg3);color:var(--text)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:12px;align-items:center}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-md);padding:32px;text-align:center;cursor:pointer;transition:all var(--transition);margin-bottom:16px}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--info);background:var(--info-light)}.upload-zone-icon{font-size:32px;margin-bottom:8px;color:var(--text3);display:flex;justify-content:center}.upload-zone-text{margin:0;color:var(--text2)}.upload-zone-hint{margin:4px 0 0;font-size:12px;color:var(--text3)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.photo-card{position:relative;border-radius:var(--radius-sm);overflow:hidden;border:2px solid var(--border);background:var(--bg3);transition:all var(--transition)}.photo-card.main{border-color:var(--accent);border-width:3px}.photo-card:hover{box-shadow:var(--shadow-md)}.photo-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.photo-badge{position:absolute;top:6px;left:6px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px}.photo-actions{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;gap:4px;padding:6px;background:linear-gradient(transparent,#000000b3)}.photo-actions button{background:none;border:none;color:#fff;cursor:pointer;font-size:14px;padding:4px;border-radius:4px;transition:background .15s;display:flex;align-items:center;justify-content:center}.photo-actions button:hover{background:#fff3}.photo-actions button.danger:hover{background:#ef444480}.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}.toast{padding:14px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-md);animation:slideIn .3s ease;min-width:280px;max-width:400px}.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--danger);color:#fff}.toast-info{background:var(--info);color:#fff}.skeleton{background:linear-gradient(90deg,var(--bg3) 25%,var(--border) 50%,var(--bg3) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-text{height:14px;margin-bottom:8px}.skeleton-title{height:20px;width:60%;margin-bottom:12px}.skeleton-card{height:80px;border-radius:var(--radius-sm)}.empty-state{text-align:center;padding:48px 24px;color:var(--text3)}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state-text{font-size:16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:8px}.gap-md{gap:12px}.gap-lg{gap:16px}.text-muted{color:var(--text2)}.text-center{text-align:center}.w-full{width:100%}.mt-sm{margin-top:8px}.mt-md{margin-top:16px}.mb-md{margin-bottom:16px}.category-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--card-bg);border-radius:var(--radius-sm);border:1px solid var(--border);transition:all var(--transition);cursor:default}.category-card:hover{box-shadow:var(--shadow-sm);border-color:var(--border-hover)}.category-card.dragging{opacity:.5;transform:scale(1.02);box-shadow:var(--shadow-md);border-color:var(--accent)}.category-card.drag-over{border-color:var(--accent);background:var(--accent-light)}.drag-handle{cursor:grab;color:var(--text3);transition:color var(--transition);display:flex;align-items:center;padding:4px;border-radius:4px}.drag-handle:hover{color:var(--text);background:var(--bg3)}.drag-handle:active{cursor:grabbing}.category-icon{width:40px;height:40px;border-radius:10px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.category-icon-empty{background:var(--bg3);color:var(--text3)}.category-info{flex:1;min-width:0}.category-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-dish-count{font-size:12px;color:var(--text3);margin-top:2px}.category-actions{display:flex;gap:4px;align-items:center}.icon-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1100;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease}.icon-picker{background:var(--card-bg);border-radius:var(--radius-lg);width:95%;max-width:560px;max-height:80vh;overflow:auto;box-shadow:var(--shadow-lg);animation:modalIn .25s ease;border:1px solid var(--border)}.icon-picker-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.icon-picker-header h3{margin:0;font-size:18px;font-weight:700}.icon-picker-search-wrapper{position:relative;padding:16px 24px;border-bottom:1px solid var(--border)}.icon-picker-search{padding-left:42px}.icon-picker-search-icon{position:absolute;left:38px;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none}.icon-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:8px;padding:20px 24px;max-height:400px;overflow-y:auto}.icon-option{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:2px solid transparent;background:var(--bg3);color:var(--text2);cursor:pointer;transition:all var(--transition);padding:0}.icon-option:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.icon-option.selected{background:var(--accent);color:#000;border-color:var(--accent);box-shadow:0 2px 8px #f59e0b4d}.icon-picker-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.icon-preview{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2)}.icon-preview-box{width:32px;height:32px;border-radius:8px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--accent)}.icon-preview-empty{background:var(--bg3);color:var(--text3)}.tooltip-wrapper{position:relative;display:inline-flex}.tooltip-wrapper:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--text);color:var(--bg);font-size:12px;font-weight:500;padding:6px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s ease;z-index:100}.tooltip-wrapper:hover:after{opacity:1}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-icon:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.special-dishes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.special-dishes-counter{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:var(--text)}.special-dishes-list{display:grid;gap:8px}.special-dish-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--card-bg);border-radius:var(--radius-sm);border:1px solid var(--border);border-left:3px solid var(--accent);transition:all var(--transition)}.special-dish-item:hover{box-shadow:var(--shadow-sm);border-color:var(--border-hover)}.special-dish-thumb{width:48px;height:48px;object-fit:cover;border-radius:6px;background:var(--bg3);flex-shrink:0}.special-dish-thumb-empty{display:flex;align-items:center;justify-content:center;color:var(--text3)}.special-dish-info{flex:1;min-width:0}.special-dish-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.special-dish-meta{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:8px;margin-top:2px}.add-dish-list{display:grid;gap:8px;max-height:400px;overflow-y:auto}.add-dish-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg3);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition)}.add-dish-item:hover{background:var(--accent-light);border-color:var(--accent)}.add-dish-thumb{width:40px;height:40px;object-fit:cover;border-radius:6px;background:var(--bg2);flex-shrink:0}.add-dish-thumb-empty{display:flex;align-items:center;justify-content:center;color:var(--text3);background:var(--bg2)}.add-dish-info{flex:1;min-width:0}.add-dish-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.add-dish-meta{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:8px;margin-top:2px}
