CSS @keyframes Rule Last Updated : 09 Oct, 2024 Comments Improve Suggest changes Like Article Like Report The CSS @keyframes rule defines animations by specifying keyframes that describe the styles to be applied at various points during the animation duration. It allows for smooth transitions and transformations in web elements, controlled through percentages or from-to values.Note:For optimal browser support, always include both 0% and 100% keyframes in your animation.Syntax:@keyframes animation-name { keyframes-selector { css-styles; }}Property value: This parameter accepts three values that are mentioned above and described below:TermDescriptionanimation-nameSpecifies the name of the animation, which is used to reference it in the animation or animation-name property.keyframes-selectorIndicates the percentage of the animation sequence (e.g., 0%, 50%, 100%) or can be defined using from (equivalent to 0%) and to (equivalent to 100%).css-stylesSpecifies one or more valid CSS style properties to be applied at each keyframe of the animation.Basic Usage ExamplesExample 1: Basic Animation Using @keyframesThis example demonstrates how to animate the background color of a div from red to blue. HTML <!DOCTYPE html> <html> <head> <style> h1 { color: white; text-align: center; } div { background: green; position: relative; animation: gfg 10s infinite; } /* keyframe CSS style */ @keyframes gfg { 0% { top: 0px; width: 00px; } 25% { top: 50px; background: LawnGreen; width: 50px; } 50% { top: 100px; background: LightGreen; width: 100px; } 75% { top: 150px; background: MediumSeaGreen; width: 150px; } 100% { top: 200px; color: white; background: Green; width: 200px; } } </style> </head> <body> <div> <h1>GeeksforGeeks</h1> </div> </body> </html> Output:Example 2: Using Multiple KeyframesYou can define multiple keyframes to create more complex animations: HTML <!DOCTYPE html> <html> <head> <style> h1 { color: white; text-align: center; } div { background: green; position: relative; animation: gfg 7s infinite; } @keyframes gfg { 0% { top: 0px; width: 0px; } 25% { top: 50px !important; background: LawnGreen; } 50% { top: 100px !important; background: LightGreen; } 100% { top: 200px !important; color: white; background: Green; width: 210px; } } </style> </head> <body> <center> <div> <h1>GeeksforGeeks</h1> </div> </center> </body> </html> Output:Supported Browsers:The browser supported by @keyframes Rule are listed below:Google ChromeEdge FirefoxOperaSafari Comment More infoAdvertise with us Next Article CSS @media Rule S Sabya_Samadder Follow Improve Article Tags : Web Technologies CSS CSS-Properties Similar Reads CSS @charset Rule The @charset rule specifies the character encoding used in the style sheet. The @charset must be the first element in the style sheet and if several @charset rules are defined then the only first one is used. It can not be used in the <style> element where the character set of the HTML page is 3 min read CSS @keyframes Rule The CSS @keyframes rule defines animations by specifying keyframes that describe the styles to be applied at various points during the animation duration. It allows for smooth transitions and transformations in web elements, controlled through percentages or from-to values.Note:For optimal browser s 3 min read CSS @media Rule The @media CSS at-rule is used to apply a different set of styles for different media/devices using the Media Queries. A Media Query is mainly used to check the height, width, resolution, and orientation(Portrait/Landscape) of the device. This CSS rule is a way out for making more out of responsive 5 min read CSS align-content property The align-content property changes the behavior of the flex-wrap property. It aligns flex lines. It is used to specify the alignment between the lines inside a flexible container. This property defines how each flex line is aligned within a flexbox and is only applicable if flex-wrap: wrap is applie 4 min read CSS align-items Property The align-items property in CSS is used to align flex items along the cross-axis within a flex container. It accepts values like flex-start, flex-end, center, baseline, and stretch, controlling the vertical alignment of items in a flexbox.Syntaxalign-items: normal | stretch | center | flex-start | f 7 min read CSS align-self Property The align-self property in CSS is used to align the selected items in the flexible container in many different manners such as flex-end, center, flex-start, etc. Syntax:align-self: auto|normal|self-start|self-end|stretch|center |baseline, first baseline, last baseline|flex-start |flex-end|baseline|s 5 min read CSS all Property The all property in CSS is the shorthand property used to set all the element's values to their initial or inherited values or in some cases used to set the values to another spreadsheet origin. This property is used to reset all the CSS properties in a document.Syntax: all: initial|inherit|unset|re 3 min read CSS animation-delay Property The animation-delay property specifies a delay for the start of an animation. Defined in seconds (s) or milliseconds (ms), this value determines how long to wait before beginning the animation. Negative values start the animation as if it had already been playing for the specified duration.Syntaxani 3 min read CSS animation-direction Property The animation-direction CSS property sets whether an animation should play forward, backward, or alternate back and forth between playing the sequence forward and backward. It controls the visual flow and repetition behavior of animations in web pages, enhancing dynamic content presentation.Syntaxan 4 min read CSS animation-duration Property The animation-duration property in CSS is essential for controlling the length of time an animation takes to complete one cycle, making it a vital tool for creating dynamic and engaging web designs.Syntax:animation-duration: time | initial | inherit;Property Value:time: This value is used to specify 3 min read Like