{"id":8310444,"date":"2025-09-09T08:46:50","date_gmt":"2025-09-09T05:46:50","guid":{"rendered":"https:\/\/elementor.com\/tools\/?p=8310444"},"modified":"2025-09-09T08:52:46","modified_gmt":"2025-09-09T05:52:46","slug":"css-animation-generator","status":"publish","type":"post","link":"https:\/\/elementor.com\/tools\/css-animation-generator\/","title":{"rendered":"CSS Animation Generator"},"content":{"rendered":"\t\t<div data-elementor-type=\"container\" data-elementor-id=\"8310443\" class=\"elementor elementor-8310443\" data-elementor-post-type=\"elementor_library\">\n\t\t\t\t<div class=\"elementor-element elementor-element-23691a2c e-flex e-con-boxed e-con e-parent\" data-id=\"23691a2c\" data-element_type=\"container\" data-e-type=\"container\">\n\t\t\t\t\t<div class=\"e-con-inner\">\n\t\t\t\t<div class=\"elementor-element elementor-element-37c3711c elementor-widget elementor-widget-html\" data-id=\"37c3711c\" data-element_type=\"widget\" data-e-type=\"widget\" data-widget_type=\"html.default\">\n\t\t\t\t<div class=\"elementor-widget-container\">\n\t\t\t\t\t<style>\r\n\/* General Layout & App Container *\/\r\n.html-viewer-app {\r\n    width: 100%;\r\n    max-width: 1280px;\r\n    margin: 0 auto;\r\n    padding: 60px 0 0;\r\n    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;\r\n}\r\n\r\n.main-content {\r\n    display: flex;\r\n    gap: 30px;\r\n    flex-wrap: wrap;\r\n}\r\n\r\n\/* Re-purposed Sections for Controls and Output *\/\r\n.input-section, .output-section {\r\n    flex: 1;\r\n    min-width: 320px;\r\n    display: flex;\r\n    flex-direction: column;\r\n    background: white;\r\n    border-radius: 8px;\r\n    border: 1.5px solid #EBEBEB;\r\n    box-shadow: 0 4px 15px rgba(0,0,0,0.07);\r\n    overflow: hidden;\r\n}\r\n\r\n.input-section {\r\n    flex-basis: 400px;\r\n    flex-grow: 1;\r\n}\r\n\r\n.output-section {\r\n    flex-basis: 500px;\r\n    flex-grow: 2;\r\n}\r\n\r\n.section-header {\r\n    background-color: #05047E;\r\n    color: white;\r\n    padding: 12px 20px;\r\n    font-weight: 500;\r\n    font-size: 1.1rem;\r\n    flex-shrink: 0;\r\n}\r\n\r\n\/* Controls Panel Styling *\/\r\n.controls-container {\r\n    padding: 25px;\r\n    display: flex;\r\n    flex-direction: column;\r\n    gap: 20px;\r\n}\r\n\r\n.control-group {\r\n    display: flex;\r\n    flex-direction: column;\r\n    gap: 8px;\r\n}\r\n\r\n.control-group label {\r\n    font-weight: 500;\r\n    color: #333;\r\n    font-size: 0.9rem;\r\n}\r\n\r\n.control-group .value-display {\r\n    font-size: 0.85rem;\r\n    color: #555;\r\n    margin-left: 10px;\r\n    font-family: 'Courier New', monospace;\r\n}\r\n\r\n.control-group select,\r\n.control-group input[type=\"range\"] {\r\n    width: 100%;\r\n    padding: 8px;\r\n    border: 1px solid #ddd;\r\n    border-radius: 4px;\r\n    font-size: 1rem;\r\n    background: #f9f9f9;\r\n}\r\n\r\ninput[type=\"range\"] {\r\n    -webkit-appearance: none;\r\n    appearance: none;\r\n    height: 8px;\r\n    background: #e9e9e9;\r\n    outline: none;\r\n    border-radius: 5px;\r\n    padding: 0;\r\n}\r\ninput[type=\"range\"]::-webkit-slider-thumb {\r\n    -webkit-appearance: none;\r\n    appearance: none;\r\n    width: 20px;\r\n    height: 20px;\r\n    background: #ff7be5;\r\n    cursor: pointer;\r\n    border-radius: 50%;\r\n    border: 2px solid white;\r\n    box-shadow: 0 0 5px rgba(0,0,0,0.2);\r\n}\r\ninput[type=\"range\"]::-moz-range-thumb {\r\n    width: 20px;\r\n    height: 20px;\r\n    background: #ff7be5;\r\n    cursor: pointer;\r\n    border-radius: 50%;\r\n    border: 2px solid white;\r\n    box-shadow: 0 0 5px rgba(0,0,0,0.2);\r\n}\r\n\r\n\/* Preview Area Styling *\/\r\n.preview-container {\r\n    display: flex;\r\n    justify-content: center;\r\n    align-items: center;\r\n    min-height: 250px;\r\n    background-color: #f7f8fc;\r\n    border-bottom: 1.5px solid #EBEBEB;\r\n    padding: 40px;\r\n}\r\n\r\n#animated-element {\r\n    width: 100px;\r\n    height: 100px;\r\n    background-color: #ff7be5;\r\n    border-radius: 8px;\r\n    color: black;\r\n    display: flex;\r\n    justify-content: center;\r\n    align-items: center;\r\n    font-weight: bold;\r\n}\r\n\r\n\/* Re-purposed Output Code Styling *\/\r\n.output-container {\r\n    position: relative;\r\n    background-color: #ffffff;\r\n    flex-grow: 1;\r\n}\r\n\r\n.output-code {\r\n    width: 100%;\r\n    height: 100%;\r\n    min-height: 200px;\r\n    box-sizing: border-box;\r\n    border: none;\r\n    outline: none;\r\n    padding: 20px;\r\n    font-family: 'Courier New', monospace;\r\n    font-size: 14px;\r\n    line-height: 1.6;\r\n    background-color: white;\r\n    color: #333;\r\n    white-space: pre-wrap;\r\n    word-break: break-all;\r\n}\r\n\r\n\/* Buttons *\/\r\n.copy-btn-container {\r\n    position: absolute;\r\n    top: 15px;\r\n    right: 15px;\r\n    z-index: 10;\r\n}\r\n\r\n.copy-btn {\r\n    background-color: rgb(255, 255, 255);\r\n    color: black;\r\n    border: 1px solid #ddd;\r\n    padding: 8px 16px;\r\n    border-radius: 4px;\r\n    cursor: pointer;\r\n    font-size: 14px;\r\n    display: flex;\r\n    align-items: center;\r\n    gap: 8px;\r\n    transition: background-color 0.2s;\r\n    box-shadow: 0 0 10px rgba(0,0,0,0.05);\r\n}\r\n\r\n.copy-btn:is(:hover, :focus, :focus-visible) {\r\n    background-color: #f6f6f6 !important;\r\n}\r\n\r\n.reset-btn {\r\n    background: none;\r\n    border: 1px solid #ccc;\r\n    color: black;\r\n    font-size: 1rem;\r\n    cursor: pointer;\r\n    padding: 10px 20px;\r\n    border-radius: 4px;\r\n    transition: all 0.2s;\r\n    margin-top: 10px;\r\n}\r\n\r\n.reset-btn:is(:hover, :focus, :focus-visible, :active) {\r\n    background: #f0f0f0;\r\n    border-color: #aaa;\r\n}\r\n\r\n\/* Success Message *\/\r\n.success-message {\r\n    position: fixed;\r\n    bottom: 20px;\r\n    left: 50%;\r\n    transform: translateX(-50%);\r\n    background-color: #05047E;\r\n    color: white;\r\n    padding: 12px 20px;\r\n    border-radius: 4px;\r\n    font-size: 14px;\r\n    opacity: 0;\r\n    transition: all 0.3s ease;\r\n    z-index: 1000;\r\n    pointer-events: none;\r\n}\r\n\r\n.success-message.show {\r\n    opacity: 1;\r\n    transform: translate(-50%, -20px);\r\n}\r\n\r\n\/* Keyframes need to be defined for the animations *\/\r\n@keyframes fadeIn {\r\n    from { opacity: 0; }\r\n    to { opacity: 1; }\r\n}\r\n@keyframes slideInUp {\r\n    from { transform: translateY(50px); opacity: 0; }\r\n    to { transform: translateY(0); opacity: 1; }\r\n}\r\n@keyframes zoomIn {\r\n    from { transform: scale(0.5); opacity: 0; }\r\n    to { transform: scale(1); opacity: 1; }\r\n}\r\n@keyframes bounce {\r\n    0%, 20%, 50%, 80%, 100% {transform: translateY(0);}\r\n    40% {transform: translateY(-30px);}\r\n    60% {transform: translateY(-15px);}\r\n}\r\n@keyframes pulse {\r\n    0% { transform: scale(1); }\r\n    50% { transform: scale(1.1); }\r\n    100% { transform: scale(1); }\r\n}\r\n\r\n\/* Responsive *\/\r\n@media (max-width: 1024px) {\r\n    .main-content {\r\n        flex-direction: column;\r\n    }\r\n    .input-section, .output-section {\r\n        flex-basis: auto;\r\n    }\r\n}\r\n<\/style>\r\n\r\n<div class=\"html-viewer-app\">\r\n    <div class=\"main-content\">\r\n\r\n        <!-- CONTROLS SECTION -->\r\n        <div class=\"input-section\">\r\n            <div class=\"section-header\">Animation Controls<\/div>\r\n            <div class=\"controls-container\">\r\n                <div class=\"control-group\">\r\n                    <label for=\"animationType\">Animation Name<\/label>\r\n                    <select id=\"animationType\">\r\n                        <option value=\"fadeIn\">Fade In<\/option>\r\n                        <option value=\"slideInUp\">Slide In Up<\/option>\r\n                        <option value=\"zoomIn\">Zoom In<\/option>\r\n                        <option value=\"bounce\">Bounce<\/option>\r\n                        <option value=\"pulse\">Pulse<\/option>\r\n                    <\/select>\r\n                <\/div>\r\n\r\n                <div class=\"control-group\">\r\n                    <label for=\"duration\">Duration <span class=\"value-display\" id=\"durationValue\">1s<\/span><\/label>\r\n                    <input type=\"range\" id=\"duration\" min=\"0.1\" max=\"5\" step=\"0.1\" value=\"1\">\r\n                <\/div>\r\n\r\n                <div class=\"control-group\">\r\n                    <label for=\"timingFunction\">Timing Function<\/label>\r\n                    <select id=\"timingFunction\">\r\n                        <option value=\"ease\">ease<\/option>\r\n                        <option value=\"ease-in\">ease-in<\/option>\r\n                        <option value=\"ease-out\">ease-out<\/option>\r\n                        <option value=\"ease-in-out\">ease-in-out<\/option>\r\n                        <option value=\"linear\">linear<\/option>\r\n                        <option value=\"cubic-bezier(0.68, -0.55, 0.27, 1.55)\">ease-in-out-back<\/option>\r\n                    <\/select>\r\n                <\/div>\r\n\r\n                <div class=\"control-group\">\r\n                    <label for=\"delay\">Delay <span class=\"value-display\" id=\"delayValue\">0s<\/span><\/label>\r\n                    <input type=\"range\" id=\"delay\" min=\"0\" max=\"5\" step=\"0.1\" value=\"0\">\r\n                <\/div>\r\n\r\n                <div class=\"control-group\">\r\n                    <label for=\"iterationCount\">Iteration Count<\/label>\r\n                    <select id=\"iterationCount\">\r\n                        <option value=\"1\">1<\/option>\r\n                        <option value=\"2\">2<\/option>\r\n                        <option value=\"3\">3<\/option>\r\n                        <option value=\"infinite\">infinite<\/option>\r\n                    <\/select>\r\n                <\/div>\r\n\r\n                <div class=\"control-group\">\r\n                    <label for=\"direction\">Direction<\/label>\r\n                    <select id=\"direction\">\r\n                        <option value=\"normal\">normal<\/option>\r\n                        <option value=\"reverse\">reverse<\/option>\r\n                        <option value=\"alternate\">alternate<\/option>\r\n                        <option value=\"alternate-reverse\">alternate-reverse<\/option>\r\n                    <\/select>\r\n                <\/div>\r\n                \r\n                <button class=\"reset-btn\" id=\"resetBtn\">Reset to Defaults<\/button>\r\n            <\/div>\r\n        <\/div>\r\n\r\n        <!-- PREVIEW & CODE OUTPUT SECTION -->\r\n        <div class=\"output-section\">\r\n            <div class=\"section-header\">Preview & Code<\/div>\r\n            <div class=\"preview-container\">\r\n                <div id=\"animated-element\">Animate Me<\/div>\r\n            <\/div>\r\n            <div class=\"output-container\">\r\n                <div class=\"copy-btn-container\">\r\n                    <button class=\"copy-btn\" id=\"copyCssBtn\">\r\n                        <svg xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\"><path d=\"M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1h1a1 1 0 0 1 1 1V14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3.5a1 1 0 0 1 1-1h1v-1z\"\/><path d=\"M9.5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3zM-1 8a.5.5 0 0 1 .5-.5h15a.5.5 0 0 1 0 1h-15A.5.5 0 0 1-1 8z\"\/><\/svg>\r\n                        Copy Code\r\n                    <\/button>\r\n                <\/div>\r\n                <pre><code class=\"output-code\" id=\"output-code\"><\/code><\/pre>\r\n            <\/div>\r\n        <\/div>\r\n    <\/div>\r\n    <div class=\"success-message\" id=\"copySuccessMessage\">CSS copied to clipboard!<\/div>\r\n<\/div>\r\n\r\n<script>\r\ndocument.addEventListener('DOMContentLoaded', () => {\r\n\r\n    \/\/ --- DOM ELEMENT REFERENCES ---\r\n    const controls = {\r\n        animationType: document.getElementById('animationType'),\r\n        duration: document.getElementById('duration'),\r\n        timingFunction: document.getElementById('timingFunction'),\r\n        delay: document.getElementById('delay'),\r\n        iterationCount: document.getElementById('iterationCount'),\r\n        direction: document.getElementById('direction')\r\n    };\r\n\r\n    const valueDisplays = {\r\n        duration: document.getElementById('durationValue'),\r\n        delay: document.getElementById('delayValue')\r\n    };\r\n\r\n    const animatedElement = document.getElementById('animated-element');\r\n    const outputCodeElement = document.getElementById('output-code');\r\n    const copyBtn = document.getElementById('copyCssBtn');\r\n    const resetBtn = document.getElementById('resetBtn');\r\n    const successMessage = document.getElementById('copySuccessMessage');\r\n\r\n    \/\/ --- KEYFRAME DEFINITIONS ---\r\n    const keyframes = {\r\n        fadeIn: `@keyframes fadeIn {\r\n    from { opacity: 0; }\r\n    to { opacity: 1; }\r\n}`,\r\n        slideInUp: `@keyframes slideInUp {\r\n    from { transform: translateY(50px); opacity: 0; }\r\n    to { transform: translateY(0); opacity: 1; }\r\n}`,\r\n        zoomIn: `@keyframes zoomIn {\r\n    from { transform: scale(0.5); opacity: 0; }\r\n    to { transform: scale(1); opacity: 1; }\r\n}`,\r\n        bounce: `@keyframes bounce {\r\n    0%, 20%, 50%, 80%, 100% {transform: translateY(0);}\r\n    40% {transform: translateY(-30px);}\r\n    60% {transform: translateY(-15px);}\r\n}`,\r\n        pulse: `@keyframes pulse {\r\n    0% { transform: scale(1); }\r\n    50% { transform: scale(1.1); }\r\n    100% { transform: scale(1); }\r\n}`\r\n    };\r\n    \r\n    \/\/ --- DEFAULT STATE ---\r\n    const defaultState = {\r\n        animationType: 'fadeIn',\r\n        duration: '1',\r\n        timingFunction: 'ease',\r\n        delay: '0',\r\n        iterationCount: '1',\r\n        direction: 'normal'\r\n    };\r\n\r\n    \/\/ --- MAIN FUNCTIONS ---\r\n    function updateAnimation() {\r\n        \/\/ Apply the animation style to the preview element\r\n        const animationCss = `${controls.animationType.value} ${controls.duration.value}s ${controls.timingFunction.value} ${controls.delay.value}s ${controls.iterationCount.value} ${controls.direction.value}`;\r\n        \r\n        \/\/ Trick to restart the animation on change\r\n        animatedElement.style.animation = 'none';\r\n        \/\/ Using requestAnimationFrame to ensure the style is applied after the 'none' state\r\n        requestAnimationFrame(() => {\r\n            setTimeout(() => {\r\n                 animatedElement.style.animation = animationCss;\r\n            }, 0);\r\n        });\r\n       \r\n        generateCssCode();\r\n    }\r\n\r\n    function generateCssCode() {\r\n        const animationName = controls.animationType.value;\r\n        const css = `.your-animated-element {\r\n    animation-name: ${animationName};\r\n    animation-duration: ${controls.duration.value}s;\r\n    animation-timing-function: ${controls.timingFunction.value};\r\n    animation-delay: ${controls.delay.value}s;\r\n    animation-iteration-count: ${controls.iterationCount.value};\r\n    animation-direction: ${controls.direction.value};\r\n    animation-fill-mode: forwards; \/* Recommended for start\/end states *\/\r\n}\r\n\r\n\/* Add these @keyframes to your CSS file *\/\r\n${keyframes[animationName]}`;\r\n        \r\n        outputCodeElement.textContent = css;\r\n    }\r\n\r\n    function updateValueDisplay(type, value) {\r\n        if (valueDisplays[type]) {\r\n            valueDisplays[type].textContent = `${parseFloat(value).toFixed(1)}s`;\r\n        }\r\n    }\r\n\r\n    \/\/ --- EVENT LISTENERS ---\r\n    Object.values(controls).forEach(control => {\r\n        control.addEventListener('input', () => {\r\n            if (control.type === 'range') {\r\n                updateValueDisplay(control.id, control.value);\r\n            }\r\n            updateAnimation();\r\n        });\r\n    });\r\n\r\n    copyBtn.addEventListener('click', () => {\r\n        navigator.clipboard.writeText(outputCodeElement.textContent).then(() => {\r\n            successMessage.classList.add('show');\r\n            setTimeout(() => {\r\n                successMessage.classList.remove('show');\r\n            }, 2000);\r\n        }).catch(err => {\r\n            console.error('Failed to copy text: ', err);\r\n        });\r\n    });\r\n    \r\n    resetBtn.addEventListener('click', () => {\r\n        Object.keys(defaultState).forEach(key => {\r\n            controls[key].value = defaultState[key];\r\n             if (controls[key].type === 'range') {\r\n                updateValueDisplay(key, defaultState[key]);\r\n            }\r\n        });\r\n        updateAnimation();\r\n    });\r\n\r\n    \/\/ --- INITIALIZATION ---\r\n    function initialize() {\r\n        Object.keys(defaultState).forEach(key => {\r\n            controls[key].value = defaultState[key];\r\n        });\r\n        updateValueDisplay('duration', defaultState.duration);\r\n        updateValueDisplay('delay', defaultState.delay);\r\n        updateAnimation();\r\n    }\r\n    \r\n    initialize();\r\n});\r\n<\/script>\r\n\t\t\t\t<\/div>\n\t\t\t\t<\/div>\n\t\t\t\t\t<\/div>\n\t\t\t\t<\/div>\n\t\t\t\t<\/div>\n\t\t\n","protected":false},"excerpt":{"rendered":"","protected":false},"author":5,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[22],"tags":[21],"class_list":["post-8310444","post","type-post","status-publish","format-standard","hentry","category-tools","tag-html-css-tools"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.2 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>CSS Animation Generator<\/title>\n<meta name=\"description\" content=\"Effortlessly add CSS animations to your Elementor website with our intuitive CSS Animation Generator. Customize duration, delay, and more to create captivating dynamic designs in 3 simple steps.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/elementor.com\/tools\/css-animation-generator\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"CSS Animation Generator\" \/>\n<meta property=\"og:description\" content=\"Effortlessly add CSS animations to your Elementor website with our intuitive CSS Animation Generator. Customize duration, delay, and more to create captivating dynamic designs in 3 simple steps.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/elementor.com\/tools\/css-animation-generator\/\" \/>\n<meta property=\"og:site_name\" content=\"Tools\" \/>\n<meta property=\"article:published_time\" content=\"2025-09-09T05:46:50+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-09-09T05:52:46+00:00\" \/>\n<meta name=\"author\" content=\"liz@148.red\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"liz@148.red\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 minute\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/elementor.com\/tools\/css-animation-generator\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/elementor.com\/tools\/css-animation-generator\/\"},\"author\":{\"name\":\"liz@148.red\",\"@id\":\"https:\/\/elementor.com\/tools\/#\/schema\/person\/80e8375cb95e6030bc2f897c41c985ac\"},\"headline\":\"CSS Animation Generator\",\"datePublished\":\"2025-09-09T05:46:50+00:00\",\"dateModified\":\"2025-09-09T05:52:46+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/elementor.com\/tools\/css-animation-generator\/\"},\"wordCount\":5,\"keywords\":[\"Html-Css-tools\"],\"articleSection\":[\"tools\"],\"inLanguage\":\"en-US\"},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/elementor.com\/tools\/css-animation-generator\/\",\"url\":\"https:\/\/elementor.com\/tools\/css-animation-generator\/\",\"name\":\"CSS Animation Generator\",\"isPartOf\":{\"@id\":\"https:\/\/elementor.com\/tools\/#website\"},\"datePublished\":\"2025-09-09T05:46:50+00:00\",\"dateModified\":\"2025-09-09T05:52:46+00:00\",\"author\":{\"@id\":\"https:\/\/elementor.com\/tools\/#\/schema\/person\/80e8375cb95e6030bc2f897c41c985ac\"},\"description\":\"Effortlessly add CSS animations to your Elementor website with our intuitive CSS Animation Generator. Customize duration, delay, and more to create captivating dynamic designs in 3 simple steps.\",\"breadcrumb\":{\"@id\":\"https:\/\/elementor.com\/tools\/css-animation-generator\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/elementor.com\/tools\/css-animation-generator\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/elementor.com\/tools\/css-animation-generator\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/elementor.com\/tools\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"CSS Animation Generator\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/elementor.com\/tools\/#website\",\"url\":\"https:\/\/elementor.com\/tools\/\",\"name\":\"Tools\",\"description\":\"Just another Elementor hosted website ;)\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/elementor.com\/tools\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/elementor.com\/tools\/#\/schema\/person\/80e8375cb95e6030bc2f897c41c985ac\",\"name\":\"liz@148.red\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/secure.gravatar.com\/avatar\/63b900d3310bd1ed40162fb27f016e9920ae66fa5be07be5153344329ef7d9d2?s=96&d=mm&r=g\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/63b900d3310bd1ed40162fb27f016e9920ae66fa5be07be5153344329ef7d9d2?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/63b900d3310bd1ed40162fb27f016e9920ae66fa5be07be5153344329ef7d9d2?s=96&d=mm&r=g\",\"caption\":\"liz@148.red\"},\"url\":\"https:\/\/elementor.com\/tools\/author\/liz148-red\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"CSS Animation Generator","description":"Effortlessly add CSS animations to your Elementor website with our intuitive CSS Animation Generator. Customize duration, delay, and more to create captivating dynamic designs in 3 simple steps.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/elementor.com\/tools\/css-animation-generator\/","og_locale":"en_US","og_type":"article","og_title":"CSS Animation Generator","og_description":"Effortlessly add CSS animations to your Elementor website with our intuitive CSS Animation Generator. Customize duration, delay, and more to create captivating dynamic designs in 3 simple steps.","og_url":"https:\/\/elementor.com\/tools\/css-animation-generator\/","og_site_name":"Tools","article_published_time":"2025-09-09T05:46:50+00:00","article_modified_time":"2025-09-09T05:52:46+00:00","author":"liz@148.red","twitter_card":"summary_large_image","twitter_misc":{"Written by":"liz@148.red","Est. reading time":"1 minute"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/elementor.com\/tools\/css-animation-generator\/#article","isPartOf":{"@id":"https:\/\/elementor.com\/tools\/css-animation-generator\/"},"author":{"name":"liz@148.red","@id":"https:\/\/elementor.com\/tools\/#\/schema\/person\/80e8375cb95e6030bc2f897c41c985ac"},"headline":"CSS Animation Generator","datePublished":"2025-09-09T05:46:50+00:00","dateModified":"2025-09-09T05:52:46+00:00","mainEntityOfPage":{"@id":"https:\/\/elementor.com\/tools\/css-animation-generator\/"},"wordCount":5,"keywords":["Html-Css-tools"],"articleSection":["tools"],"inLanguage":"en-US"},{"@type":"WebPage","@id":"https:\/\/elementor.com\/tools\/css-animation-generator\/","url":"https:\/\/elementor.com\/tools\/css-animation-generator\/","name":"CSS Animation Generator","isPartOf":{"@id":"https:\/\/elementor.com\/tools\/#website"},"datePublished":"2025-09-09T05:46:50+00:00","dateModified":"2025-09-09T05:52:46+00:00","author":{"@id":"https:\/\/elementor.com\/tools\/#\/schema\/person\/80e8375cb95e6030bc2f897c41c985ac"},"description":"Effortlessly add CSS animations to your Elementor website with our intuitive CSS Animation Generator. Customize duration, delay, and more to create captivating dynamic designs in 3 simple steps.","breadcrumb":{"@id":"https:\/\/elementor.com\/tools\/css-animation-generator\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/elementor.com\/tools\/css-animation-generator\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/elementor.com\/tools\/css-animation-generator\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/elementor.com\/tools\/"},{"@type":"ListItem","position":2,"name":"CSS Animation Generator"}]},{"@type":"WebSite","@id":"https:\/\/elementor.com\/tools\/#website","url":"https:\/\/elementor.com\/tools\/","name":"Tools","description":"Just another Elementor hosted website ;)","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/elementor.com\/tools\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/elementor.com\/tools\/#\/schema\/person\/80e8375cb95e6030bc2f897c41c985ac","name":"liz@148.red","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/secure.gravatar.com\/avatar\/63b900d3310bd1ed40162fb27f016e9920ae66fa5be07be5153344329ef7d9d2?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/63b900d3310bd1ed40162fb27f016e9920ae66fa5be07be5153344329ef7d9d2?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/63b900d3310bd1ed40162fb27f016e9920ae66fa5be07be5153344329ef7d9d2?s=96&d=mm&r=g","caption":"liz@148.red"},"url":"https:\/\/elementor.com\/tools\/author\/liz148-red\/"}]}},"_links":{"self":[{"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/posts\/8310444","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/users\/5"}],"replies":[{"embeddable":true,"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/comments?post=8310444"}],"version-history":[{"count":1,"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/posts\/8310444\/revisions"}],"predecessor-version":[{"id":8310447,"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/posts\/8310444\/revisions\/8310447"}],"wp:attachment":[{"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/media?parent=8310444"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/categories?post=8310444"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/elementor.com\/tools\/wp-json\/wp\/v2\/tags?post=8310444"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}