diff --git a/.gitignore b/.gitignore
index 882ed9b21e..3c6d3c4249 100644
--- a/.gitignore
+++ b/.gitignore
@@ -17,3 +17,5 @@ __pycache__/
*.py[cod]
*$py.class
demo/models/*
+dist/*
+*.h5
diff --git a/README.md b/README.md
index f81da0b9ee..841a383058 100644
--- a/README.md
+++ b/README.md
@@ -42,11 +42,13 @@ The core Interface class is initialized with three parameters:
- `inputs`: the name of the input interface
- `outputs`: the name of the output interface
-Calling the `launch()` function of the `Interface` object produces the interface shown in image below.
+Calling the `launch()` function of the `Interface` object produces the interface shown in image below. Click on the screenshot to go the live interface in our getting started page.
+
+ +
+ + +### 1. Inception Net [![alt text](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1c6gQiW88wKBwWq96nqEwuQ1Kyt5LejiU?usp=sharing) + +Now, let's do a machine learning example. We're going to wrap an +interface around the InceptionV3 image classifier, which we'll load +using Tensorflow! Since this is an image classification model, we will use the `Image` input interface. +We'll output a dictionary of labels and their corresponding confidence scores with the `Label` output +interface. (The original Inception Net architecture [can be found here](https://arxiv.org/abs/1409.4842)) + +```python +import gradio as gr +import tensorflow as tf +import numpy as np +import requests + +inception_net = tf.keras.applications.InceptionV3() # load the model + +# Download human-readable labels for ImageNet. +response = requests.get("https://git.io/JJkYN") +labels = response.text.split("\n") + +def classify_image(inp): + inp = inp.reshape((-1, 299, 299, 3)) + inp = tf.keras.applications.inception_v3.preprocess_input(inp) + prediction = inception_net.predict(inp).flatten() + return {labels[i]: float(prediction[i]) for i in range(1000)} + +image = gr.inputs.Image(shape=(299, 299, 3)) +label = gr.outputs.Label(num_top_classes=3) + +gr.Interface(fn=classify_image, inputs=image, outputs=label).launch() +``` +This code will produce the interface below. The interface gives you a way to test +Inception Net by dragging and dropping images, and also allows you to use naturally modify the input image using image editing tools that +appear when you click EDIT. Notice here we provided actual `gradio.inputs` and `gradio.outputs` objects to the Interface +function instead of using string shortcuts. This lets us use built-in preprocessing (e.g. image resizing) +and postprocessing (e.g. choosing the number of labels to display) provided by these +interfaces. + ++ +
+ +You can supply your own model instead of the pretrained model above, as well as use different kinds of models or functions. Here's a list of the interfaces we currently support, along with their preprocessing / postprocessing parameters: + +**Input Interfaces**: +- `Sketchpad(shape=(28, 28), invert_colors=True, flatten=False, scale=1/255, shift=0, dtype='float64')` +- `Webcam(image_width=224, image_height=224, num_channels=3, label=None)` +- `Textbox(lines=1, placeholder=None, label=None, numeric=False)` +- `Radio(choices, label=None)` +- `Dropdown(choices, label=None)` +- `CheckboxGroup(choices, label=None)` +- `Slider(minimum=0, maximum=100, default=None, label=None)` +- `Image(shape=(224, 224, 3), image_mode='RGB', scale=1/127.5, shift=-1, label=None)` +- `Microphone()` + +**Output Interfaces**: +- `Label(num_top_classes=None, label=None)` +- `KeyValues(label=None)` +- `Textbox(lines=1, placeholder=None, label=None)` +- `Image(label=None, plot=False)` + +Interfaces can also be combined together, for multiple-input or multiple-output models. + +### 2. Real-Time MNIST [![alt text](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/drive/1LXJqwdkZNkt1J_yfLWQ3FLxbG2cAF8p4?usp=sharing) + +Let's wrap a fun `Sketchpad`-to-`Label` UI around MNIST. For this example, we'll take advantage of the `live` +feature in the library. Set `live=True` inside `Interface()`> to have it run continuous predictions. +We've abstracted the model training from the code below, but you can see the full code on the colab link. + +```python +import tensorflow as tf +import gradio as gr +from urllib.request import urlretrieve + +urlretrieve("https://gr-models.s3-us-west-2.amazonaws.com/mnist-model.h5","mnist-model.h5") +model = tf.keras.models.load_model("mnist-model.h5") + +def recognize_digit(inp): + prediction = model.predict(inp.reshape(1, 28, 28, 1)).tolist()[0] + return {str(i): prediction[i] for i in range(10)} + +sketchpad = gr.inputs.Sketchpad() +label = gr.outputs.Label(num_top_classes=3) + +gr.Interface(fn=recognize_digit, inputs=sketchpad, + outputs=label, live=True).launch() +``` + +This code will produce the interface below. + ++ +
+ +## Contributing: +If you would like to contribute and your contribution is small, you can directly open a pull request (PR). If you would like to contribute a larger feature, we recommend first creating an issue with a proposed design for discussion. Please see our contributing guidelines for more info. + +## License: +Gradio is licensed under the Apache License 2.0 + +## See more: + +You can find many more examples (like GPT-2, model comparison, multiple inputs, and numerical interfaces) as well as more info on usage on our website: www.gradio.app + +See, also, the accompanying paper: ["Gradio: Hassle-Free Sharing and Testing of ML Models in the Wild"](https://arxiv.org/pdf/1906.02569.pdf), *ICML HILL 2019*, and please use the citation below. + +``` +@article{abid2019gradio, +title={Gradio: Hassle-Free Sharing and Testing of ML Models in the Wild}, +author={Abid, Abubakar and Abdalla, Ali and Abid, Ali and Khan, Dawood and Alfozan, Abdulrahman and Zou, James}, +journal={arXiv preprint arXiv:1906.02569}, +year={2019} +} +``` + + diff --git a/gradio-0.9.9.5/gradio.egg-info/PKG-INFO b/gradio-0.9.9.5/gradio.egg-info/PKG-INFO new file mode 100644 index 0000000000..5e4b2c410e --- /dev/null +++ b/gradio-0.9.9.5/gradio.egg-info/PKG-INFO @@ -0,0 +1,11 @@ +Metadata-Version: 1.0 +Name: gradio +Version: 0.9.9.5 +Summary: Python library for easily interacting with trained machine learning models +Home-page: https://github.com/gradio-app/gradio-UI +Author: Abubakar Abid +Author-email: a12d@stanford.edu +License: UNKNOWN +Description: UNKNOWN +Keywords: machine learning,visualization,reproducibility +Platform: UNKNOWN diff --git a/gradio-0.9.9.5/gradio.egg-info/SOURCES.txt b/gradio-0.9.9.5/gradio.egg-info/SOURCES.txt new file mode 100644 index 0000000000..c9bca4f9c4 --- /dev/null +++ b/gradio-0.9.9.5/gradio.egg-info/SOURCES.txt @@ -0,0 +1,89 @@ +MANIFEST.in +README.md +setup.py +gradio/__init__.py +gradio/inputs.py +gradio/interface.py +gradio/networking.py +gradio/outputs.py +gradio/preprocessing_utils.py +gradio/strings.py +gradio/tunneling.py +gradio/validation_data.py +gradio.egg-info/PKG-INFO +gradio.egg-info/SOURCES.txt +gradio.egg-info/dependency_links.txt +gradio.egg-info/requires.txt +gradio.egg-info/top_level.txt +gradio/static/apple-app-site-association +gradio/static/css/gradio.css +gradio/static/css/loading.css +gradio/static/css/style.css +gradio/static/css/interfaces/input/checkbox_group.css +gradio/static/css/interfaces/input/csv.css +gradio/static/css/interfaces/input/dropdown.css +gradio/static/css/interfaces/input/image.css +gradio/static/css/interfaces/input/microphone.css +gradio/static/css/interfaces/input/radio.css +gradio/static/css/interfaces/input/sketchpad.css +gradio/static/css/interfaces/input/slider.css +gradio/static/css/interfaces/input/textbox.css +gradio/static/css/interfaces/input/webcam.css +gradio/static/css/interfaces/output/image.css +gradio/static/css/interfaces/output/key_values.css +gradio/static/css/interfaces/output/label.css +gradio/static/css/interfaces/output/textbox.css +gradio/static/css/vendor/tui-color-picker.css +gradio/static/css/vendor/tui-image-editor.css +gradio/static/img/logo.png +gradio/static/img/logo_error.png +gradio/static/img/logo_inline.png +gradio/static/img/logo_loading.gif +gradio/static/img/logo_mini.png +gradio/static/img/logo_only.png +gradio/static/img/mic.png +gradio/static/img/mic_recording.png +gradio/static/img/table.png +gradio/static/img/webcam.png +gradio/static/img/vendor/icon-a.svg +gradio/static/img/vendor/icon-b.svg +gradio/static/img/vendor/icon-c.svg +gradio/static/img/vendor/icon-d.svg +gradio/static/js/all_io.js +gradio/static/js/all_io.js.bak +gradio/static/js/gradio.js +gradio/static/js/utils.js +gradio/static/js/interfaces/input/checkbox.js +gradio/static/js/interfaces/input/checkbox_group.js +gradio/static/js/interfaces/input/dropdown.js +gradio/static/js/interfaces/input/image.js +gradio/static/js/interfaces/input/microphone.js +gradio/static/js/interfaces/input/radio.js +gradio/static/js/interfaces/input/sketchpad.js +gradio/static/js/interfaces/input/slider.js +gradio/static/js/interfaces/input/textbox.js +gradio/static/js/interfaces/input/webcam.js +gradio/static/js/interfaces/output/image.js +gradio/static/js/interfaces/output/key_values.js +gradio/static/js/interfaces/output/label.js +gradio/static/js/interfaces/output/textbox.js +gradio/static/js/vendor/FileSaver.min.js +gradio/static/js/vendor/black-theme.js +gradio/static/js/vendor/fabric.js +gradio/static/js/vendor/jquery.min.js +gradio/static/js/vendor/p5.dom.min.js +gradio/static/js/vendor/p5.min.js +gradio/static/js/vendor/p5.sound.min.js +gradio/static/js/vendor/papaparse.min.js +gradio/static/js/vendor/sketchpad.js +gradio/static/js/vendor/tui-code-snippet.min.js +gradio/static/js/vendor/tui-color-picker.js +gradio/static/js/vendor/tui-image-editor.js +gradio/static/js/vendor/wavesurfer.min.js +gradio/static/js/vendor/webcam.min.js +gradio/static/js/vendor/white-theme.js +gradio/templates/index.html +test/test_inputs.py +test/test_interface.py +test/test_networking.py +test/test_outputs.py \ No newline at end of file diff --git a/gradio-0.9.9.5/gradio.egg-info/dependency_links.txt b/gradio-0.9.9.5/gradio.egg-info/dependency_links.txt new file mode 100644 index 0000000000..8b13789179 --- /dev/null +++ b/gradio-0.9.9.5/gradio.egg-info/dependency_links.txt @@ -0,0 +1 @@ + diff --git a/gradio-0.9.9.5/gradio.egg-info/requires.txt b/gradio-0.9.9.5/gradio.egg-info/requires.txt new file mode 100644 index 0000000000..6bb220b721 --- /dev/null +++ b/gradio-0.9.9.5/gradio.egg-info/requires.txt @@ -0,0 +1,7 @@ +numpy +requests +paramiko +scipy +IPython +scikit-image +analytics-python diff --git a/gradio-0.9.9.5/gradio.egg-info/top_level.txt b/gradio-0.9.9.5/gradio.egg-info/top_level.txt new file mode 100644 index 0000000000..25aceddaba --- /dev/null +++ b/gradio-0.9.9.5/gradio.egg-info/top_level.txt @@ -0,0 +1 @@ +gradio diff --git a/gradio-0.9.9.5/gradio/__init__.py b/gradio-0.9.9.5/gradio/__init__.py new file mode 100644 index 0000000000..bc36d88ec7 --- /dev/null +++ b/gradio-0.9.9.5/gradio/__init__.py @@ -0,0 +1 @@ +from gradio.interface import * # This makes it possible to import `Interface` as `gradio.Interface`. diff --git a/gradio-0.9.9.5/gradio/inputs.py b/gradio-0.9.9.5/gradio/inputs.py new file mode 100644 index 0000000000..cfd1c51e3f --- /dev/null +++ b/gradio-0.9.9.5/gradio/inputs.py @@ -0,0 +1,288 @@ +""" +This module defines various classes that can serve as the `input` to an interface. Each class must inherit from +`AbstractInput`, and each class must define a path to its template. All of the subclasses of `AbstractInput` are +automatically added to a registry, which allows them to be easily referenced in other parts of the code. +""" + +from abc import ABC, abstractmethod +from gradio import preprocessing_utils, validation_data +import numpy as np +import PIL.Image, PIL.ImageOps +import time +import warnings +import json +import datetime +import os + +# Where to find the static resources associated with each template. +# BASE_INPUT_INTERFACE_TEMPLATE_PATH = 'static/js/interfaces/input/{}.js' +BASE_INPUT_INTERFACE_JS_PATH = 'static/js/interfaces/input/{}.js' + + +class AbstractInput(ABC): + """ + An abstract class for defining the methods that all gradio inputs should have. + When this is subclassed, it is automatically added to the registry + """ + def __init__(self, label): + self.label = label + + def get_validation_inputs(self): + """ + An interface can optionally implement a method that returns a list of examples inputs that it should be able to + accept and preprocess for validation purposes. + """ + return [] + + def get_template_context(self): + """ + :return: a dictionary with context variables for the javascript file associated with the context + """ + return {"label": self.label} + + def preprocess(self, inp): + """ + By default, no pre-processing is applied to text. + """ + return inp + + def process_example(self, example): + """ + Proprocess example for UI + """ + return example + + @classmethod + def get_shortcut_implementations(cls): + """ + Return dictionary of shortcut implementations + """ + return {} + + +class Sketchpad(AbstractInput): + def __init__(self, shape=(28, 28), invert_colors=True, + flatten=False, label=None): + self.image_width = shape[0] + self.image_height = shape[1] + self.invert_colors = invert_colors + self.flatten = flatten + super().__init__(label) + + @classmethod + def get_shortcut_implementations(cls): + return { + "sketchpad": {}, + } + + def preprocess(self, inp): + """ + Default preprocessing method for the SketchPad is to convert the sketch to black and white and resize 28x28 + """ + im_transparent = preprocessing_utils.decode_base64_to_image(inp) + im = PIL.Image.new("RGBA", im_transparent.size, "WHITE") # Create a white background for the alpha channel + im.paste(im_transparent, (0, 0), im_transparent) + im = im.convert('L') + if self.invert_colors: + im = PIL.ImageOps.invert(im) + im = im.resize((self.image_width, self.image_height)) + if self.flatten: + array = np.array(im).flatten().reshape(1, self.image_width * self.image_height) + else: + array = np.array(im).flatten().reshape(1, self.image_width, self.image_height) + return array + + def process_example(self, example): + return preprocessing_utils.convert_file_to_base64(example) + + +class Webcam(AbstractInput): + def __init__(self, shape=(224, 224), label=None): + self.image_width = shape[0] + self.image_height = shape[1] + self.num_channels = 3 + super().__init__(label) + + def get_validation_inputs(self): + return validation_data.BASE64_COLOR_IMAGES + + @classmethod + def get_shortcut_implementations(cls): + return { + "webcam": {}, + } + + def preprocess(self, inp): + """ + Default preprocessing method for is to convert the picture to black and white and resize to be 48x48 + """ + im = preprocessing_utils.decode_base64_to_image(inp) + im = im.convert('RGB') + im = preprocessing_utils.resize_and_crop(im, (self.image_width, self.image_height)) + return np.array(im) + + +class Textbox(AbstractInput): + def __init__(self, lines=1, placeholder=None, default=None, numeric=False, label=None): + self.lines = lines + self.placeholder = placeholder + self.default = default + self.numeric = numeric + super().__init__(label) + + def get_validation_inputs(self): + return validation_data.ENGLISH_TEXTS + + def get_template_context(self): + return { + "lines": self.lines, + "placeholder": self.placeholder, + "default": self.default, + **super().get_template_context() + } + + @classmethod + def get_shortcut_implementations(cls): + return { + "text": {}, + "textbox": {"lines": 7}, + "number": {"numeric": True} + } + + def preprocess(self, inp): + """ + Cast type of input + """ + if self.numeric: + return float(inp) + else: + return inp + + +class Radio(AbstractInput): + def __init__(self, choices, label=None): + self.choices = choices + super().__init__(label) + + def get_template_context(self): + return { + "choices": self.choices, + **super().get_template_context() + } + + +class Dropdown(AbstractInput): + def __init__(self, choices, label=None): + self.choices = choices + super().__init__(label) + + def get_template_context(self): + return { + "choices": self.choices, + **super().get_template_context() + } + + +class CheckboxGroup(AbstractInput): + def __init__(self, choices, label=None): + self.choices = choices + super().__init__(label) + + def get_template_context(self): + return { + "choices": self.choices, + **super().get_template_context() + } + + +class Slider(AbstractInput): + def __init__(self, minimum=0, maximum=100, default=None, label=None): + self.minimum = minimum + self.maximum = maximum + self.default = minimum if default is None else default + super().__init__(label) + + def get_template_context(self): + return { + "minimum": self.minimum, + "maximum": self.maximum, + "default": self.default, + **super().get_template_context() + } + + @classmethod + def get_shortcut_implementations(cls): + return { + "slider": {}, + } + + +class Checkbox(AbstractInput): + def __init__(self, label=None): + super().__init__(label) + + @classmethod + def get_shortcut_implementations(cls): + return { + "checkbox": {}, + } + + +class Image(AbstractInput): + def __init__(self, shape=(224, 224), image_mode='RGB', label=None): + self.image_width = shape[0] + self.image_height = shape[1] + self.image_mode = image_mode + super().__init__(label) + + def get_validation_inputs(self): + return validation_data.BASE64_COLOR_IMAGES + + @classmethod + def get_shortcut_implementations(cls): + return { + "image": {}, + } + + def get_template_context(self): + return { + **super().get_template_context() + } + + def preprocess(self, inp): + """ + Default preprocessing method for is to convert the picture to black and white and resize to be 48x48 + """ + im = preprocessing_utils.decode_base64_to_image(inp) + with warnings.catch_warnings(): + warnings.simplefilter("ignore") + im = im.convert(self.image_mode) + + im = preprocessing_utils.resize_and_crop(im, (self.image_width, self.image_height)) + return np.array(im) + + def process_example(self, example): + if os.path.exists(example): + return preprocessing_utils.convert_file_to_base64(example) + else: + return example + + +class Microphone(AbstractInput): + def __init__(self, label=None): + super().__init__(label) + + def preprocess(self, inp): + """ + By default, no pre-processing is applied to a microphone input file + """ + file_obj = preprocessing_utils.decode_base64_to_wav_file(inp) + mfcc_array = preprocessing_utils.generate_mfcc_features_from_audio_file(file_obj.name) + return mfcc_array + + +# Automatically adds all shortcut implementations in AbstractInput into a dictionary. +shortcuts = {} +for cls in AbstractInput.__subclasses__(): + for shortcut, parameters in cls.get_shortcut_implementations().items(): + shortcuts[shortcut] = cls(**parameters) \ No newline at end of file diff --git a/gradio-0.9.9.5/gradio/interface.py b/gradio-0.9.9.5/gradio/interface.py new file mode 100644 index 0000000000..6a9e148754 --- /dev/null +++ b/gradio-0.9.9.5/gradio/interface.py @@ -0,0 +1,413 @@ +""" +This is the core file in the `gradio` package, and defines the Interface class, including methods for constructing the +interface using the input and output types. +""" + +import tempfile +import traceback +import webbrowser + +import gradio.inputs +import gradio.outputs +from gradio import networking, strings +from distutils.version import StrictVersion +import pkg_resources +import requests +import random +import time +import inspect +from IPython import get_ipython +import sys +import weakref +import analytics +import socket + + +PKG_VERSION_URL = "https://gradio.app/api/pkg-version" +analytics.write_key = "uxIFddIEuuUcFLf9VgH2teTEtPlWdkNy" +analytics_url = 'https://api.gradio.app/' +hostname = socket.gethostname() +ip_address = socket.gethostbyname(hostname) + + +class Interface: + """ + The Interface class represents a general input/output interface for a machine learning model. During construction, + the appropriate inputs and outputs + """ + instances = weakref.WeakSet() + + def __init__(self, fn, inputs, outputs, saliency=None, verbose=False, examples=None, + live=False, show_input=True, show_output=True, + capture_session=False, title=None, description=None, + thumbnail=None, server_name=networking.LOCALHOST_NAME): + """ + :param fn: a function that will process the input panel data from the interface and return the output panel data. + :param inputs: a string or `AbstractInput` representing the input interface. + :param outputs: a string or `AbstractOutput` representing the output interface. + """ + def get_input_instance(iface): + if isinstance(iface, str): + return gradio.inputs.shortcuts[iface.lower()] + elif isinstance(iface, gradio.inputs.AbstractInput): + return iface + else: + raise ValueError("Input interface must be of type `str` or " + "`AbstractInput`") + + def get_output_instance(iface): + if isinstance(iface, str): + return gradio.outputs.shortcuts[iface.lower()] + elif isinstance(iface, gradio.outputs.AbstractOutput): + return iface + else: + raise ValueError( + "Output interface must be of type `str` or " + "`AbstractOutput`" + ) + if isinstance(inputs, list): + self.input_interfaces = [get_input_instance(i) for i in inputs] + else: + self.input_interfaces = [get_input_instance(inputs)] + if isinstance(outputs, list): + self.output_interfaces = [get_output_instance(i) for i in outputs] + else: + self.output_interfaces = [get_output_instance(outputs)] + if not isinstance(fn, list): + fn = [fn] + self.output_interfaces *= len(fn) + self.predict = fn + self.verbose = verbose + self.status = "OFF" + self.saliency = saliency + self.live = live + self.show_input = show_input + self.show_output = show_output + self.flag_hash = random.getrandbits(32) + self.capture_session = capture_session + self.session = None + self.server_name = server_name + self.title = title + self.description = description + self.thumbnail = thumbnail + self.examples = examples + self.server_port = None + self.simple_server = None + Interface.instances.add(self) + + data = {'fn': fn, + 'inputs': inputs, + 'outputs': outputs, + 'saliency': saliency, + 'live': live, + 'capture_session': capture_session, + 'host_name': hostname, + 'ip_address': ip_address + } + try: + requests.post(analytics_url + 'gradio-initiated-analytics/', + data=data) + except requests.ConnectionError: + print("gradio-initiated-analytics/ Connection Error") + + def get_config_file(self): + config = { + "input_interfaces": [ + (iface.__class__.__name__.lower(), iface.get_template_context()) + for iface in self.input_interfaces], + "output_interfaces": [ + (iface.__class__.__name__.lower(), iface.get_template_context()) + for iface in self.output_interfaces], + "function_count": len(self.predict), + "live": self.live, + "show_input": self.show_input, + "show_output": self.show_output, + "title": self.title, + "description": self.description, + "thumbnail": self.thumbnail + } + try: + param_names = inspect.getfullargspec(self.predict[0])[0] + for iface, param in zip(config["input_interfaces"], param_names): + if not iface[1]["label"]: + iface[1]["label"] = param.replace("_", " ") + for i, iface in enumerate(config["output_interfaces"]): + ret_name = "Output " + str(i + 1) if len(config["output_interfaces"]) > 1 else "Output" + if not iface[1]["label"]: + iface[1]["label"] = ret_name + except ValueError: + pass + + return config + + + def process(self, raw_input): + processed_input = [input_interface.preprocess( + raw_input[i]) for i, input_interface in + enumerate(self.input_interfaces)] + predictions = [] + durations = [] + for predict_fn in self.predict: + start = time.time() + if self.capture_session and not(self.session is None): + graph, sess = self.session + with graph.as_default(): + with sess.as_default(): + prediction = predict_fn(*processed_input) + else: + try: + prediction = predict_fn(*processed_input) + except ValueError as exception: + if str(exception).endswith("is not an element of this " + "graph."): + raise ValueError("It looks like you might be using " + "tensorflow < 2.0. Please " + "pass capture_session=True in " + "Interface to avoid the 'Tensor is " + "not an element of this graph.' " + "error.") + else: + raise exception + duration = time.time() - start + + if len(self.output_interfaces) == len(self.predict): + prediction = [prediction] + durations.append(duration) + predictions.extend(prediction) + processed_output = [output_interface.postprocess( + predictions[i]) for i, output_interface in enumerate(self.output_interfaces)] + return processed_output, durations + + def validate(self): + if self.validate_flag: + if self.verbose: + print("Interface already validated") + return + validation_inputs = self.input_interface.get_validation_inputs() + n = len(validation_inputs) + if n == 0: + self.validate_flag = True + if self.verbose: + print( + "No validation samples for this interface... skipping validation." + ) + return + for m, msg in enumerate(validation_inputs): + if self.verbose: + print( + "Validating samples: {}/{} [".format(m+1, n) + + "=" * (m + 1) + + "." * (n - m - 1) + + "]", + end="\r", + ) + try: + processed_input = self.input_interface.preprocess(msg) + prediction = self.predict(processed_input) + except Exception as e: + data = {'error': e} + try: + requests.post(analytics_url + 'gradio-error-analytics/', + data=data) + except requests.ConnectionError: + print("gradio-error-analytics/ Connection Error") + if self.verbose: + print("\n----------") + print( + "Validation failed, likely due to incompatible pre-processing and model input. See below:\n" + ) + print(traceback.format_exc()) + break + try: + _ = self.output_interface.postprocess(prediction) + except Exception as e: + data = {'error': e} + try: + requests.post(analytics_url + 'gradio-error-analytics/', + data=data) + except requests.ConnectionError: + print("gradio-error-analytics/ Connection Error") + if self.verbose: + print("\n----------") + print( + "Validation failed, likely due to incompatible model output and post-processing." + "See below:\n" + ) + print(traceback.format_exc()) + break + else: # This means if a break was not explicitly called + self.validate_flag = True + if self.verbose: + print("\n\nValidation passed successfully!") + return + raise RuntimeError("Validation did not pass") + + def close(self): + if self.simple_server and not(self.simple_server.fileno() == -1): # checks to see if server is running + print("Closing Gradio server on port {}...".format(self.server_port)) + networking.close_server(self.simple_server) + + def launch(self, inline=None, inbrowser=None, share=False, validate=True, debug=False): + """ + Standard method shared by interfaces that creates the interface and sets up a websocket to communicate with it. + :param inline: boolean. If True, then a gradio interface is created inline (e.g. in jupyter or colab notebook) + :param inbrowser: boolean. If True, then a new browser window opens with the gradio interface. + :param share: boolean. If True, then a share link is generated using ngrok is displayed to the user. + :param validate: boolean. If True, then the validation is run if the interface has not already been validated. + """ + # if validate and not self.validate_flag: + # self.validate() + + if self.capture_session: + try: + import tensorflow as tf + self.session = tf.get_default_graph(), \ + tf.keras.backend.get_session() + except (ImportError, AttributeError): # If they are using TF >= 2.0 or don't have TF, just ignore this. + pass + + output_directory = tempfile.mkdtemp() + # Set up a port to serve the directory containing the static files with interface. + server_port, httpd = networking.start_simple_server(self, output_directory, self.server_name) + path_to_local_server = "http://{}:{}/".format(self.server_name, server_port) + networking.build_template(output_directory) + + self.server_port = server_port + self.status = "RUNNING" + self.simple_server = httpd + + is_colab = False + try: # Check if running interactively using ipython. + from_ipynb = get_ipython() + if "google.colab" in str(from_ipynb): + is_colab = True + except NameError: + data = {'error': 'NameError in launch method'} + try: + requests.post(analytics_url + 'gradio-error-analytics/', + data=data) + except requests.ConnectionError: + print("Connection Error") + pass + + try: + current_pkg_version = pkg_resources.require("gradio")[0].version + latest_pkg_version = requests.get(url=PKG_VERSION_URL).json()["version"] + if StrictVersion(latest_pkg_version) > StrictVersion(current_pkg_version): + print("IMPORTANT: You are using gradio version {}, " + "however version {} " + "is available, please upgrade.".format( + current_pkg_version, latest_pkg_version)) + print('--------') + except: # TODO(abidlabs): don't catch all exceptions + pass + + if not is_colab: + print(strings.en["RUNNING_LOCALLY"].format(path_to_local_server)) + else: + if debug: + print("Colab notebook detected. This cell will run indefinitely so that you can see errors and logs. " + "To turn off, set debug=False in launch().") + else: + print("Colab notebook detected. To show errors in colab notebook, set debug=True in launch()") + + if share: + try: + share_url = networking.setup_tunnel(server_port) + print("Running on External URL:", share_url) + except RuntimeError: + data = {'error': 'RuntimeError in launch method'} + try: + requests.post(analytics_url + 'gradio-error-analytics/', + data=data) + except requests.ConnectionError: + print("Connection Error") + share_url = None + if self.verbose: + print(strings.en["NGROK_NO_INTERNET"]) + else: + if ( + is_colab + ): # For a colab notebook, create a public link even if share is False. + share_url = networking.setup_tunnel(server_port) + print("Running on External URL:", share_url) + if self.verbose: + print(strings.en["COLAB_NO_LOCAL"]) + else: # If it's not a colab notebook and share=False, print a message telling them about the share option. + if self.verbose: + print(strings.en["PUBLIC_SHARE_TRUE"]) + share_url = None + + if inline is None: + try: # Check if running interactively using ipython. + get_ipython() + inline = True + if inbrowser is None: + inbrowser = False + except NameError: + inline = False + if inbrowser is None: + inbrowser = True + else: + if inbrowser is None: + inbrowser = False + + if inbrowser and not is_colab: + webbrowser.open( + path_to_local_server + ) # Open a browser tab with the interface. + if inline: + from IPython.display import IFrame, display + + if ( + is_colab + ): # Embed the remote interface page if on google colab; + # otherwise, embed the local page. + while not networking.url_ok(share_url): + time.sleep(1) + display(IFrame(share_url, width=1000, height=500)) + else: + display(IFrame(path_to_local_server, width=1000, height=500)) + + config = self.get_config_file() + config["share_url"] = share_url + + processed_examples = [] + if self.examples is not None: + for example_set in self.examples: + processed_set = [] + for iface, example in zip(self.input_interfaces, example_set): + processed_set.append(iface.process_example(example)) + processed_examples.append(processed_set) + config["examples"] = processed_examples + + networking.set_config(config, output_directory) + + if debug: + while True: + sys.stdout.flush() + time.sleep(0.1) + + launch_method = 'browser' if inbrowser else 'inline' + data = {'launch_method': launch_method, + 'is_google_colab': is_colab, + 'is_sharing_on': share, + 'share_url': share_url, + 'host_name': hostname, + 'ip_address': ip_address + } + try: + requests.post(analytics_url + 'gradio-hosted-launched-analytics/', + data=data) + except requests.ConnectionError: + print("Connection Error") + return httpd, path_to_local_server, share_url + + @classmethod + def get_instances(cls): + return list(Interface.instances) #Returns list of all current instances + + +def reset_all(): + for io in Interface.get_instances(): + io.close() diff --git a/gradio-0.9.9.5/gradio/networking.py b/gradio-0.9.9.5/gradio/networking.py new file mode 100644 index 0000000000..5d0853e4c8 --- /dev/null +++ b/gradio-0.9.9.5/gradio/networking.py @@ -0,0 +1,252 @@ +""" +Defines helper methods useful for setting up ports, launching servers, and handling `ngrok` +""" + +import os +import socket +import threading +from http.server import HTTPServer as BaseHTTPServer, SimpleHTTPRequestHandler +import pkg_resources +from distutils import dir_util +from gradio import inputs, outputs +import json +from gradio.tunneling import create_tunnel +import urllib.request +from shutil import copyfile +import requests +import sys + + +INITIAL_PORT_VALUE = ( + 7860 +) # The http server will try to open on port 7860. If not available, 7861, 7862, etc. +TRY_NUM_PORTS = ( + 100 +) # Number of ports to try before giving up and throwing an exception. +LOCALHOST_NAME = os.getenv('GRADIO_SERVER_NAME', "127.0.0.1") +GRADIO_API_SERVER = "https://api.gradio.app/v1/tunnel-request" + +STATIC_TEMPLATE_LIB = pkg_resources.resource_filename("gradio", "templates/") +STATIC_PATH_LIB = pkg_resources.resource_filename("gradio", "static/") +STATIC_PATH_TEMP = "static/" +TEMPLATE_TEMP = "index.html" +BASE_JS_FILE = "static/js/all_io.js" +CONFIG_FILE = "static/config.json" + +ASSOCIATION_PATH_IN_STATIC = "static/apple-app-site-association" +ASSOCIATION_PATH_IN_ROOT = "apple-app-site-association" + +FLAGGING_DIRECTORY = 'static/flagged/' +FLAGGING_FILENAME = 'data.txt' + + +def build_template(temp_dir): + """ + Create HTML file with supporting JS and CSS files in a given directory. + :param temp_dir: string with path to temp directory in which the html file should be built + """ + dir_util.copy_tree(STATIC_TEMPLATE_LIB, temp_dir) + dir_util.copy_tree(STATIC_PATH_LIB, os.path.join( + temp_dir, STATIC_PATH_TEMP)) + + # Move association file to root of temporary directory. + copyfile(os.path.join(temp_dir, ASSOCIATION_PATH_IN_STATIC), + os.path.join(temp_dir, ASSOCIATION_PATH_IN_ROOT)) + + +def render_template_with_tags(template_path, context): + """ + Combines the given template with a given context dictionary by replacing all of the occurrences of tags (enclosed + in double curly braces) with corresponding values. + :param template_path: a string with the path to the template file + :param context: a dictionary whose string keys are the tags to replace and whose string values are the replacements. + """ + print(template_path, context) + with open(template_path) as fin: + old_lines = fin.readlines() + new_lines = render_string_or_list_with_tags(old_lines, context) + with open(template_path, "w") as fout: + for line in new_lines: + fout.write(line) + + +def render_string_or_list_with_tags(old_lines, context): + # Handle string case + if isinstance(old_lines, str): + for key, value in context.items(): + old_lines = old_lines.replace(r"{{" + key + r"}}", str(value)) + return old_lines + + # Handle list case + new_lines = [] + for line in old_lines: + for key, value in context.items(): + line = line.replace(r"{{" + key + r"}}", str(value)) + new_lines.append(line) + return new_lines + + +def set_config(config, temp_dir): + config_file = os.path.join(temp_dir, CONFIG_FILE) + with open(config_file, "w") as output: + json.dump(config, output) + + +def get_first_available_port(initial, final): + """ + Gets the first open port in a specified range of port numbers + :param initial: the initial value in the range of port numbers + :param final: final (exclusive) value in the range of port numbers, should be greater than `initial` + :return: + """ + for port in range(initial, final): + try: + s = socket.socket() # create a socket object + s.bind((LOCALHOST_NAME, port)) # Bind to the port + s.close() + return port + except OSError: + pass + raise OSError( + "All ports from {} to {} are in use. Please close a port.".format( + initial, final + ) + ) + + +def serve_files_in_background(interface, port, directory_to_serve=None, server_name=LOCALHOST_NAME): + class HTTPHandler(SimpleHTTPRequestHandler): + """This handler uses server.base_path instead of always using os.getcwd()""" + def _set_headers(self): + self.send_response(200) + self.send_header("Content-type", "application/json") + self.end_headers() + + def translate_path(self, path): + path = SimpleHTTPRequestHandler.translate_path(self, path) + relpath = os.path.relpath(path, os.getcwd()) + fullpath = os.path.join(self.server.base_path, relpath) + return fullpath + + def log_message(self, format, *args): + return + + def do_POST(self): + # Read body of the request. + if self.path == "/api/predict/": + # Make the prediction. + self._set_headers() + data_string = self.rfile.read( + int(self.headers["Content-Length"])) + msg = json.loads(data_string) + raw_input = msg["data"] + prediction, durations = interface.process(raw_input) + + output = {"data": prediction, "durations": durations} + if interface.saliency is not None: + saliency = interface.saliency(raw_input, prediction) + output['saliency'] = saliency.tolist() + # if interface.always_flag: + # msg = json.loads(data_string) + # flag_dir = os.path.join(FLAGGING_DIRECTORY, str(interface.hash)) + # os.makedirs(flag_dir, exist_ok=True) + # output_flag = {'input': interface.input_interface.rebuild_flagged(flag_dir, msg['data']), + # 'output': interface.output_interface.rebuild_flagged(flag_dir, processed_output), + # } + # with open(os.path.join(flag_dir, FLAGGING_FILENAME), 'a+') as f: + # f.write(json.dumps(output_flag)) + # f.write("\n") + + # Prepare return json dictionary. + self.wfile.write(json.dumps(output).encode()) + + elif self.path == "/api/flag/": + self._set_headers() + data_string = self.rfile.read( + int(self.headers["Content-Length"])) + msg = json.loads(data_string) + flag_dir = os.path.join(FLAGGING_DIRECTORY, + str(interface.flag_hash)) + os.makedirs(flag_dir, exist_ok=True) + output = {'inputs': [interface.input_interfaces[ + i].rebuild_flagged( + flag_dir, msg['data']['input_data']) for i + in range(len(interface.input_interfaces))], + 'outputs': [interface.output_interfaces[ + i].rebuild_flagged( + flag_dir, msg['data']['output_data']) for i + in range(len(interface.output_interfaces))], + 'message': msg['data']['message']} + + with open(os.path.join(flag_dir, FLAGGING_FILENAME), 'a+') as f: + f.write(json.dumps(output)) + f.write("\n") + + else: + self.send_error(404, 'Path not found: {}'.format(self.path)) + + class HTTPServer(BaseHTTPServer): + """The main server, you pass in base_path which is the path you want to serve requests from""" + + def __init__(self, base_path, server_address, RequestHandlerClass=HTTPHandler): + self.base_path = base_path + BaseHTTPServer.__init__(self, server_address, RequestHandlerClass) + + httpd = HTTPServer(directory_to_serve, (server_name, port)) + + # Now loop forever + def serve_forever(): + try: + while True: + sys.stdout.flush() + httpd.serve_forever() + except (KeyboardInterrupt, OSError): + httpd.shutdown() + httpd.server_close() + + thread = threading.Thread(target=serve_forever, daemon=False) + thread.start() + + return httpd + + +def start_simple_server(interface, directory_to_serve=None, server_name=None): + port = get_first_available_port( + INITIAL_PORT_VALUE, INITIAL_PORT_VALUE + TRY_NUM_PORTS + ) + httpd = serve_files_in_background(interface, port, directory_to_serve, server_name) + return port, httpd + + +def close_server(server): + server.server_close() + + +def url_request(url): + try: + req = urllib.request.Request( + url=url, headers={"content-type": "application/json"} + ) + res = urllib.request.urlopen(req, timeout=10) + return res + except Exception as e: + raise RuntimeError(str(e)) + + +def setup_tunnel(local_server_port): + response = url_request(GRADIO_API_SERVER) + if response and response.code == 200: + try: + payload = json.loads(response.read().decode("utf-8"))[0] + return create_tunnel(payload, LOCALHOST_NAME, local_server_port) + + except Exception as e: + raise RuntimeError(str(e)) + + +def url_ok(url): + try: + r = requests.head(url) + return r.status_code == 200 + except ConnectionError: + return False \ No newline at end of file diff --git a/gradio-0.9.9.5/gradio/outputs.py b/gradio-0.9.9.5/gradio/outputs.py new file mode 100644 index 0000000000..3c2e5e633c --- /dev/null +++ b/gradio-0.9.9.5/gradio/outputs.py @@ -0,0 +1,174 @@ +""" +This module defines various classes that can serve as the `output` to an interface. Each class must inherit from +`AbstractOutput`, and each class must define a path to its template. All of the subclasses of `AbstractOutput` are +automatically added to a registry, which allows them to be easily referenced in other parts of the code. +""" + +from abc import ABC, abstractmethod +import numpy as np +import json +from gradio import preprocessing_utils +import datetime +import operator +from numbers import Number + +# Where to find the static resources associated with each template. +BASE_OUTPUT_INTERFACE_JS_PATH = 'static/js/interfaces/output/{}.js' + + +class AbstractOutput(ABC): + """ + An abstract class for defining the methods that all gradio inputs should have. + When this is subclassed, it is automatically added to the registry + """ + def __init__(self, label): + self.label = label + + def get_template_context(self): + """ + :return: a dictionary with context variables for the javascript file associated with the context + """ + return {"label": self.label} + + def postprocess(self, prediction): + """ + Any postprocessing needed to be performed on function output. + """ + return prediction + + @classmethod + def get_shortcut_implementations(cls): + """ + Return dictionary of shortcut implementations + """ + return {} + + +class Label(AbstractOutput): + LABEL_KEY = "label" + CONFIDENCE_KEY = "confidence" + CONFIDENCES_KEY = "confidences" + + def __init__(self, num_top_classes=None, label=None): + self.num_top_classes = num_top_classes + super().__init__(label) + + def postprocess(self, prediction): + if isinstance(prediction, str) or isinstance(prediction, Number): + return {"label": str(prediction)} + elif isinstance(prediction, dict): + sorted_pred = sorted( + prediction.items(), + key=operator.itemgetter(1), + reverse=True + ) + if self.num_top_classes is not None: + sorted_pred = sorted_pred[:self.num_top_classes] + return { + self.LABEL_KEY: sorted_pred[0][0], + self.CONFIDENCES_KEY: [ + { + self.LABEL_KEY: pred[0], + self.CONFIDENCE_KEY: pred[1] + } for pred in sorted_pred + ] + } + elif isinstance(prediction, int) or isinstance(prediction, float): + return {self.LABEL_KEY: str(prediction)} + else: + raise ValueError("The `Label` output interface expects one of: a string label, or an int label, a " + "float label, or a dictionary whose keys are labels and values are confidences.") + + @classmethod + def get_shortcut_implementations(cls): + return { + "label": {}, + } + + +class KeyValues(AbstractOutput): + def __init__(self, label=None): + super().__init__(label) + + def postprocess(self, prediction): + if isinstance(prediction, dict): + return prediction + else: + raise ValueError("The `KeyValues` output interface expects an output that is a dictionary whose keys are " + "labels and values are corresponding values.") + + @classmethod + def get_shortcut_implementations(cls): + return { + "key_values": {}, + } + + +class Textbox(AbstractOutput): + def __init__(self, label=None): + super().__init__(label) + + def get_template_context(self): + return { + **super().get_template_context() + } + + @classmethod + def get_shortcut_implementations(cls): + return { + "text": {}, + "number": {}, + } + + def postprocess(self, prediction): + if isinstance(prediction, str) or isinstance(prediction, int) or isinstance(prediction, float): + return str(prediction) + else: + raise ValueError("The `Textbox` output interface expects an output that is one of: a string, or" + "an int/float that can be converted to a string.") + + +class Image(AbstractOutput): + def __init__(self, plot=False, label=None): + self.plot = plot + super().__init__(label) + + @classmethod + def get_shortcut_implementations(cls): + return { + "image": {}, + "plot": {"plot": True} + } + + def postprocess(self, prediction): + """ + """ + if self.plot: + try: + return preprocessing_utils.encode_plot_to_base64(prediction) + except: + raise ValueError("The `Image` output interface expects a `matplotlib.pyplot` object" + "if plt=True.") + else: + try: + return preprocessing_utils.encode_array_to_base64(prediction) + except: + raise ValueError("The `Image` output interface (with plt=False) expects a numpy array.") + + def rebuild_flagged(self, dir, msg): + """ + Default rebuild method to decode a base64 image + """ + im = preprocessing_utils.decode_base64_to_image(msg) + timestamp = datetime.datetime.now() + filename = 'output_{}.png'.format(timestamp. + strftime("%Y-%m-%d-%H-%M-%S")) + im.save('{}/{}'.format(dir, filename), 'PNG') + return filename + + +# Automatically adds all shortcut implementations in AbstractInput into a dictionary. +shortcuts = {} +for cls in AbstractOutput.__subclasses__(): + for shortcut, parameters in cls.get_shortcut_implementations().items(): + shortcuts[shortcut] = cls(**parameters) diff --git a/gradio-0.9.9.5/gradio/preprocessing_utils.py b/gradio-0.9.9.5/gradio/preprocessing_utils.py new file mode 100644 index 0000000000..def83aee91 --- /dev/null +++ b/gradio-0.9.9.5/gradio/preprocessing_utils.py @@ -0,0 +1,148 @@ +from PIL import Image, ImageOps +from io import BytesIO +import base64 +import tempfile +import scipy.io.wavfile +from scipy.fftpack import dct +import numpy as np +import skimage + + +######################### +# IMAGE PRE-PROCESSING +######################### +def decode_base64_to_image(encoding): + content = encoding.split(';')[1] + image_encoded = content.split(',')[1] + return Image.open(BytesIO(base64.b64decode(image_encoded))) + + +def convert_file_to_base64(img): + with open(img, "rb") as image_file: + encoded_string = base64.b64encode(image_file.read()) + base64_str = str(encoded_string, 'utf-8') + type = img.split(".")[-1] + return "data:image/" + type + ";base64," + base64_str + +def encode_plot_to_base64(plt): + with BytesIO() as output_bytes: + plt.savefig(output_bytes, format="png") + bytes_data = output_bytes.getvalue() + plt.close() + base64_str = str(base64.b64encode(bytes_data), 'utf-8') + return "data:image/png;base64," + base64_str + +def encode_array_to_base64(image_array): + with BytesIO() as output_bytes: + PIL_image = Image.fromarray(skimage.img_as_ubyte(image_array)) + PIL_image.save(output_bytes, 'PNG') + bytes_data = output_bytes.getvalue() + base64_str = str(base64.b64encode(bytes_data), 'utf-8') + return "data:image/png;base64," + base64_str + + +def resize_and_crop(img, size, crop_type='center'): + """ + Resize and crop an image to fit the specified size. + args: + size: `(width, height)` tuple. + crop_type: can be 'top', 'middle' or 'bottom', depending on this + value, the image will cropped getting the 'top/left', 'middle' or + 'bottom/right' of the image to fit the size. + raises: + ValueError: if an invalid `crop_type` is provided. + """ + if crop_type == "top": + center = (0, 0) + elif crop_type == "center": + center = (0.5, 0.5) + else: + raise ValueError + return ImageOps.fit(img, size, centering=center) + +################## +# AUDIO FILES +################## + +def decode_base64_to_wav_file(encoding): + inp = encoding.split(';')[1].split(',')[1] + wav_obj = base64.b64decode(inp) + file_obj = tempfile.NamedTemporaryFile() + file_obj.close() + with open(file_obj.name, 'wb') as f: + f.write(wav_obj) + return file_obj + + +def generate_mfcc_features_from_audio_file(wav_filename, + pre_emphasis=0.95, + frame_size= 0.025, + frame_stride=0.01, + NFFT=512, + nfilt=40, + num_ceps=12, + cep_lifter=22): + """ + Loads and preprocesses a .wav audio file into mfcc coefficients, the typical inputs to models. + Adapted from: https://haythamfayek.com/2016/04/21/speech-processing-for-machine-learning.html + :param wav_filename: string name of audio file to process. + :param pre_emphasis: a float factor, typically 0.95 or 0.97, which amplifies high frequencies. + :param frame_size: a float that is the length, in seconds, of time frame over which to take the fft. + :param frame_stride: a float that is the offset, in seconds, between consecutive time frames. + :param NFFT: The number of points in the short-time fft for each time frame. + :param nfilt: The number of filters on the Mel-scale to extract frequency bands. + :param num_ceps: the number of cepstral coefficients to retrain. + :param cep_lifter: the int factor, by which to de-emphasize higher-frequency. + :return: a numpy array of mfcc coefficients. + """ + sample_rate, signal = scipy.io.wavfile.read(wav_filename) + emphasized_signal = np.append(signal[0], signal[1:] - pre_emphasis * signal[:-1]) + + frame_length, frame_step = frame_size * sample_rate, frame_stride * sample_rate # Convert from seconds to samples + signal_length = len(emphasized_signal) + frame_length = int(round(frame_length)) + frame_step = int(round(frame_step)) + num_frames = int(np.ceil(float(np.abs(signal_length - frame_length)) / frame_step)) # Make sure that we have at least 1 frame + + pad_signal_length = num_frames * frame_step + frame_length + z = np.zeros((pad_signal_length - signal_length)) + pad_signal = np.append(emphasized_signal, z) # Pad Signal to make sure that all frames have equal number of samples without truncating any samples from the original signal + + indices = np.tile(np.arange(0, frame_length), (num_frames, 1)) + np.tile(np.arange(0, num_frames * frame_step, frame_step), (frame_length, 1)).T + frames = pad_signal[indices.astype(np.int32, copy=False)] + + frames *= np.hamming(frame_length) + mag_frames = np.absolute(np.fft.rfft(frames, NFFT)) # Magnitude of the FFT + pow_frames = ((1.0 / NFFT) * ((mag_frames) ** 2)) # Power Spectrum + + low_freq_mel = 0 + high_freq_mel = (2595 * np.log10(1 + (sample_rate / 2) / 700)) # Convert Hz to Mel + mel_points = np.linspace(low_freq_mel, high_freq_mel, nfilt + 2) # Equally spaced in Mel scale + hz_points = (700 * (10**(mel_points / 2595) - 1)) # Convert Mel to Hz + bin = np.floor((NFFT + 1) * hz_points / sample_rate) + + fbank = np.zeros((nfilt, int(np.floor(NFFT / 2 + 1)))) + for m in range(1, nfilt + 1): + f_m_minus = int(bin[m - 1]) # left + f_m = int(bin[m]) # center + f_m_plus = int(bin[m + 1]) # right + + for k in range(f_m_minus, f_m): + fbank[m - 1, k] = (k - bin[m - 1]) / (bin[m] - bin[m - 1]) + for k in range(f_m, f_m_plus): + fbank[m - 1, k] = (bin[m + 1] - k) / (bin[m + 1] - bin[m]) + filter_banks = np.dot(pow_frames, fbank.T) + filter_banks = np.where(filter_banks == 0, np.finfo(float).eps, filter_banks) # Numerical Stability + filter_banks = 20 * np.log10(filter_banks) # dB + + mfcc = dct(filter_banks, type=2, axis=1, norm='ortho')[:, 0: (num_ceps + 1)] # Keep filters 1-13 by default. + (nframes, ncoeff) = mfcc.shape + n = np.arange(ncoeff) + lift = 1 + (cep_lifter / 2) * np.sin(np.pi * n / cep_lifter) + mfcc *= lift + + filter_banks -= (np.mean(filter_banks, axis=0) + 1e-8) + mfcc -= (np.mean(mfcc, axis=0) + 1e-8) + return mfcc[np.newaxis, :, :] # Create a batch dimension. + + diff --git a/gradio-0.9.9.5/gradio/static/apple-app-site-association b/gradio-0.9.9.5/gradio/static/apple-app-site-association new file mode 100644 index 0000000000..36c39e3174 --- /dev/null +++ b/gradio-0.9.9.5/gradio/static/apple-app-site-association @@ -0,0 +1,11 @@ +{ + "applinks": { + "apps": [], + "details": [ + { + "appID": "RHW8FBGSTX.app.gradio.Gradio", + "paths": ["*"] + } + ] + } +} \ No newline at end of file diff --git a/gradio-0.9.9.5/gradio/static/css/gradio.css b/gradio-0.9.9.5/gradio/static/css/gradio.css new file mode 100644 index 0000000000..f5f39cb8a8 --- /dev/null +++ b/gradio-0.9.9.5/gradio/static/css/gradio.css @@ -0,0 +1,125 @@ +.panel { + min-width: 300px; + flex: 1 1 0; + display: inline-block; + box-sizing: border-box; +} +.panel:first-child { + margin-right: 24px; +} +.panel:last-child { + margin-left: 8px; +} +.panel_header, .interface { + background-color: whitesmoke; +} +.panel_header { + text-transform: uppercase; + font-family: Arial; + color: #888; + padding: 6px 6px 0; + font-size: 14px; + font-weight: bold; + display: flex; +} +.input_interfaces, .output_interfaces { + margin-bottom: 16px; +} +.interface { + height: 360px; + padding: 8px; + display: flex; + flex-flow: column; +} +.loading { + margin-left: auto; +} +.loading img { + display: none; +} +.panel_buttons { + display: flex; + margin-left: -8px; +} +.panel_buttons > * { + margin-left: 8px; +} +.submit { + display: none; +} +.submit, .clear, .panel_button { + background-color: whitesmoke !important; + flex-grow: 1; + padding: 8px !important; + box-sizing: border-box; + text-transform: uppercase; + font-weight: bold; + border: 0 none !important; +} +.submit { + background-color: #EEA45D !important; + color: white !important; +} +.submit, .flag_message { + flex-grow: 2 !important; + margin-right: 8px; +} +.flag_message { + padding: 8px !important; + background-color: whitesmoke !important; +} + +.upload_zone { + font-weight: bold; + font-size: 24px; + color: #BBB; + cursor: pointer; + width: 100%; + height: 100%; + box-sizing: border-box; + display: flex; + align-items: center; + justify-content: center; + text-align: center; + line-height: 1.5em; + flex-flow: column; +} +.upload_zone img { + height: 120px; + +} +.drop_zone { + border: dashed 8px #DDD; +} +.edit_holder { + display: flex; + justify-content: flex-end; + margin-bottom: 6px; +} +.interface_button { + padding: 6px; + text-transform: uppercase; + font-weight: bold; + font-size: 14px; +} +.overlay { + position: absolute; + height: 100vh; + width: 100vw; + position: fixed; + z-index: 1; + background-color: rgba(0, 0, 0, 0.7); + top: 0; + left: 0; +} +.flag.flagged { + background-color: pink !important; +} +.loading { + justify-content: center; + align-items: center; +} + +.invisible { + display: none !important; +} diff --git a/gradio-0.9.9.5/gradio/static/css/interfaces/input/checkbox_group.css b/gradio-0.9.9.5/gradio/static/css/interfaces/input/checkbox_group.css new file mode 100644 index 0000000000..7d93fdcfd2 --- /dev/null +++ b/gradio-0.9.9.5/gradio/static/css/interfaces/input/checkbox_group.css @@ -0,0 +1,11 @@ +.checkbox_group { + display: flex; + align-items: center; + font-size: 18px; +} +.checkbox_group input, .checkbox { + margin: 0px 4px 0px 0px; +} +.checkbox_group label { + margin-right: 16px; +} diff --git a/gradio-0.9.9.5/gradio/static/css/interfaces/input/csv.css b/gradio-0.9.9.5/gradio/static/css/interfaces/input/csv.css new file mode 100644 index 0000000000..afbc4e6ff6 --- /dev/null +++ b/gradio-0.9.9.5/gradio/static/css/interfaces/input/csv.css @@ -0,0 +1,26 @@ +.table_holder { + max-width: 100%; + max-height: 100%; + overflow: scroll; + display: none; +} +.csv_preview { + background-color: white; + max-width: 100%; + max-height: 100%; + font-size: 12px; + font-family: monospace; +} +.csv_preview tr { + border-bottom: solid 1px black; +} +.csv_preview tr.header td { + background-color: #EEA45D; + font-weight: bold; +} +.csv_preview td { + padding: 2px 4px; +} +.csv_preview td:nth-child(even) { + background-color: whitesmoke; +} diff --git a/gradio-0.9.9.5/gradio/static/css/interfaces/input/dropdown.css b/gradio-0.9.9.5/gradio/static/css/interfaces/input/dropdown.css new file mode 100644 index 0000000000..e69de29bb2 diff --git a/gradio-0.9.9.5/gradio/static/css/loading.css b/gradio-0.9.9.5/gradio/static/css/loading.css new file mode 100644 index 0000000000..ce3628d18a --- /dev/null +++ b/gradio-0.9.9.5/gradio/static/css/loading.css @@ -0,0 +1,6875 @@ +.ld.reverse { + -webkit-animation-direction: reverse; + animation-direction: reverse; +} +.ld.xhalf { + -webkit-animation-duration: 0.5s; + animation-duration: 0.5s; +} +.ld.x1 { + -webkit-animation-duration: 1s; + animation-duration: 1s; +} +.ld.x2 { + -webkit-animation-duration: 2s; + animation-duration: 2s; +} +.ld.x4 { + -webkit-animation-duration: 4s; + animation-duration: 4s; +} +.ld.running { + -webkit-animation-play-state: running; + animation-play-state: running; +} +.ld.paused { + -webkit-animation-play-state: paused; + animation-play-state: paused; +} +.ld.f00 { + -webkit-animation-delay: 0s; + animation-delay: 0s; +} +.ld.f01 { + -webkit-animation-delay: -0.1s; + animation-delay: -0.1s; +} +.ld.f02 { + -webkit-animation-delay: -0.2s; + animation-delay: -0.2s; +} +.ld.f03 { + -webkit-animation-delay: -0.3s; + animation-delay: -0.3s; +} +.ld.f04 { + -webkit-animation-delay: -0.4s; + animation-delay: -0.4s; +} +.ld.f05 { + -webkit-animation-delay: -0.5s; + animation-delay: -0.5s; +} +.ld.f06 { + -webkit-animation-delay: -0.6s; + animation-delay: -0.6s; +} +.ld.f07 { + -webkit-animation-delay: -0.7s; + animation-delay: -0.7s; +} +.ld.f08 { + -webkit-animation-delay: -0.8s; + animation-delay: -0.8s; +} +.ld.f09 { + -webkit-animation-delay: -0.9s; + animation-delay: -0.9s; +} +.ld.f10 { + -webkit-animation-delay: -1s; + animation-delay: -1s; +} +.ld-ball, +.ld-ring, +.ld-hourglass, +.ld-loader, +.ld-cross, +.ld-square, +.ld-pie, +.ld-spinner { + width: 1em; + height: 1em; + position: relative; + color: inherit; + display: inline-block; +/* + &:before + content: "â—Ž" + display: block + visibility: hidden + */ +} +.ld-ball:after, +.ld-ring:after, +.ld-hourglass:after, +.ld-loader:after, +.ld-cross:after, +.ld-square:after, +.ld-pie:after, +.ld-spinner:after { + position: absolute; + margin: auto; + width: 100%; + height: 100%; + top: 0; + left: 0; + right: 0; + bottom: 0; + content: " "; + display: inline-block; + background: center center no-repeat; + background-size: cover; +} +.ld-ball:after { + border-radius: 50%; + background: currentColor; +} +.ld-pie:after { + width: 0; + height: 0; + border-radius: 50%; + border-style: solid; + border-width: 0.5em; + -webkit-background-clip: padding-box; + border-color: currentColor currentColor currentColor transparent; +} +.ld-ring:after { + border-radius: 50%; + border-style: solid; + border-width: 0.15em; + -webkit-background-clip: padding-box; + border-color: currentColor currentColor currentColor transparent; + box-sizing: border-box; +} +.ld-hourglass:after { + width: 0; + height: 0; + background: none; + border-radius: 50%; + border-style: solid; + border-width: 0.5em; + border-color: currentColor transparent currentColor transparent; +} +.ld-cross:after { + width: 18%; + height: 18%; + background: currentColor; + box-shadow: 0 0.18em 0 1px currentColor, 0 -0.18em 0 1px currentColor, 0.18em 0 0 1px currentColor, -0.18em 0 0 1px currentColor, 0 0.36em 0 1px currentColor, 0 -0.36em 0 1px currentColor, 0.36em 0 0 1px currentColor, -0.36em 0 0 1px currentColor; +} +.ld-square:after { + width: 90%; + height: 90%; + background: currentColor; +} +.ld-spinner:after { + width: 20%; + height: 20%; + border-radius: 50%; + background: none; + box-shadow: 0 0.5em 0 0 currentColor,0 -.5em 0 0 currentColor,.5em 0 0 0 currentColor,-.5em 0 0 0 currentColor,.35355339059327373em .35355339059327373em 0 0 currentColor,-.35355339059327373em .35355339059327373em 0 0 currentColor,.35355339059327373em -.35355339059327373em 0 0 currentColor,-.35355339059327373em -.35355339059327373em 0 0 currentColor; +} +.ld-loader { + background-size: cover; +} +@keyframes ld-blink { + 0% { + opacity: 1; + } + 49% { + opacity: 1; + } + 50% { + opacity: 0; + } + 100% { + opacity: 0; + } +} +@-webkit-keyframes ld-blink { + 0% { + opacity: 1; + } + 49% { + opacity: 1; + } + 50% { + opacity: 0; + } + 100% { + opacity: 0; + } +} +.ld.ld-blink { + -webkit-animation: ld-blink 1s infinite linear; + animation: ld-blink 1s infinite linear; +} +@keyframes ld-blur { + 0% { + filter: blur(0); + } + 50% { + filter: blur(5px); + } + 100% { + filter: blur(0); + } +} +@-webkit-keyframes ld-blur { + 0% { + filter: blur(0); + } + 50% { + filter: blur(5px); + } + 100% { + filter: blur(0); + } +} +.ld.ld-blur { + -webkit-animation: ld-blur 1s infinite; + animation: ld-blur 1s infinite; +} +@keyframes ld-breath { + 0% { + -webkit-transform: scale(0.86); + transform: scale(0.86); + } + 50% { + -webkit-transform: scale(1.06); + transform: scale(1.06); + } + 100% { + -webkit-transform: scale(0.86); + transform: scale(0.86); + } +} +@-webkit-keyframes ld-breath { + 0% { + -webkit-transform: scale(0.86); + transform: scale(0.86); + } + 50% { + -webkit-transform: scale(1.06); + transform: scale(1.06); + } + 100% { + -webkit-transform: scale(0.86); + transform: scale(0.86); + } +} +.ld.ld-breath { + -webkit-animation: ld-breath 1s infinite; + animation: ld-breath 1s infinite; +} +@keyframes ld-broadcast { + 0% { + box-shadow: 0 0 0 3px rgba(0,0,0,0.9); + } + 19% { + box-shadow: 0 0 0 2px rgba(0,0,0,0.7); + } + 20% { + box-shadow: 0 0 0 6px rgba(0,0,0,0.8); + } + 39% { + box-shadow: 0 0 0 5px rgba(0,0,0,0.6); + } + 40% { + box-shadow: 0 0 0 9px rgba(0,0,0,0.7); + } + 60% { + box-shadow: 0 0 0 8px rgba(0,0,0,0.6); + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 100% { + box-shadow: 0 0 0 0px rgba(0,0,0,0.2); + } +} +@-webkit-keyframes ld-broadcast { + 0% { + box-shadow: 0 0 0 3px rgba(0,0,0,0.9); + } + 19% { + box-shadow: 0 0 0 2px rgba(0,0,0,0.7); + } + 20% { + box-shadow: 0 0 0 6px rgba(0,0,0,0.8); + } + 39% { + box-shadow: 0 0 0 5px rgba(0,0,0,0.6); + } + 40% { + box-shadow: 0 0 0 9px rgba(0,0,0,0.7); + } + 60% { + box-shadow: 0 0 0 8px rgba(0,0,0,0.6); + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 100% { + box-shadow: 0 0 0 0px rgba(0,0,0,0.2); + } +} +.ld.ld-broadcast { + -webkit-animation: ld-broadcast 1s infinite ease-out; + animation: ld-broadcast 1s infinite ease-out; + border-radius: 50%; +} +@keyframes ld-clock { + 0% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + 8.333% { + -webkit-transform: rotate(30deg); + transform: rotate(30deg); + } + 16.667% { + -webkit-transform: rotate(60deg); + transform: rotate(60deg); + } + 25% { + -webkit-transform: rotate(90deg); + transform: rotate(90deg); + } + 33.333% { + -webkit-transform: rotate(120deg); + transform: rotate(120deg); + } + 41.667% { + -webkit-transform: rotate(150deg); + transform: rotate(150deg); + } + 50% { + -webkit-transform: rotate(180deg); + transform: rotate(180deg); + } + 58.333% { + -webkit-transform: rotate(210deg); + transform: rotate(210deg); + } + 66.667% { + -webkit-transform: rotate(240deg); + transform: rotate(240deg); + } + 75% { + -webkit-transform: rotate(270deg); + transform: rotate(270deg); + } + 83.333% { + -webkit-transform: rotate(300deg); + transform: rotate(300deg); + } + 91.667% { + -webkit-transform: rotate(330deg); + transform: rotate(330deg); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +@-webkit-keyframes ld-clock { + 0% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + 8.333% { + -webkit-transform: rotate(30deg); + transform: rotate(30deg); + } + 16.667% { + -webkit-transform: rotate(60deg); + transform: rotate(60deg); + } + 25% { + -webkit-transform: rotate(90deg); + transform: rotate(90deg); + } + 33.333% { + -webkit-transform: rotate(120deg); + transform: rotate(120deg); + } + 41.667% { + -webkit-transform: rotate(150deg); + transform: rotate(150deg); + } + 50% { + -webkit-transform: rotate(180deg); + transform: rotate(180deg); + } + 58.333% { + -webkit-transform: rotate(210deg); + transform: rotate(210deg); + } + 66.667% { + -webkit-transform: rotate(240deg); + transform: rotate(240deg); + } + 75% { + -webkit-transform: rotate(270deg); + transform: rotate(270deg); + } + 83.333% { + -webkit-transform: rotate(300deg); + transform: rotate(300deg); + } + 91.667% { + -webkit-transform: rotate(330deg); + transform: rotate(330deg); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +.ld.ld-clock { + -webkit-animation: ld-clock 9s infinite cubic-bezier(0, 0.7, 0.3, 1); + animation: ld-clock 9s infinite cubic-bezier(0, 0.7, 0.3, 1); +} +@keyframes ld-cycle { + 0%, 50%, 100% { + animation-timing-function: cubic-bezier(0.5, 0.5, 0.5, 0.5); + } + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + } + 50% { + -webkit-transform: rotate(180deg); + transform: rotate(180deg); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +@-webkit-keyframes ld-cycle { + 0%, 50%, 100% { + animation-timing-function: cubic-bezier(0.5, 0.5, 0.5, 0.5); + } + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + } + 50% { + -webkit-transform: rotate(180deg); + transform: rotate(180deg); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +.ld.ld-cycle { + -webkit-animation: ld-cycle 1s infinite linear; + animation: ld-cycle 1s infinite linear; +} +@keyframes ld-fade { + 0% { + opacity: 1; + } + 100% { + opacity: 0; + } +} +@-webkit-keyframes ld-fade { + 0% { + opacity: 1; + } + 100% { + opacity: 0; + } +} +.ld.ld-fade { + -webkit-animation: ld-fade 1s infinite linear; + animation: ld-fade 1s infinite linear; +} +@keyframes ld-flip { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateY(0deg) rotateX(0deg); + transform: rotateY(0deg) rotateX(0deg); + } + 25% { + -webkit-transform: rotateY(180deg) rotateX(0deg); + transform: rotateY(180deg) rotateX(0deg); + } + 50% { + -webkit-transform: rotateY(180deg) rotateX(180deg); + transform: rotateY(180deg) rotateX(180deg); + } + 75% { + -webkit-transform: rotateY(0deg) rotateX(180deg); + transform: rotateY(0deg) rotateX(180deg); + } + 100% { + -webkit-transform: rotateY(0deg) rotateX(0deg); + transform: rotateY(0deg) rotateX(0deg); + } +} +@-webkit-keyframes ld-flip { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateY(0deg) rotateX(0deg); + transform: rotateY(0deg) rotateX(0deg); + } + 25% { + -webkit-transform: rotateY(180deg) rotateX(0deg); + transform: rotateY(180deg) rotateX(0deg); + } + 50% { + -webkit-transform: rotateY(180deg) rotateX(180deg); + transform: rotateY(180deg) rotateX(180deg); + } + 75% { + -webkit-transform: rotateY(0deg) rotateX(180deg); + transform: rotateY(0deg) rotateX(180deg); + } + 100% { + -webkit-transform: rotateY(0deg) rotateX(0deg); + transform: rotateY(0deg) rotateX(0deg); + } +} +.ld.ld-flip { + -webkit-animation: ld-flip 2s infinite; + animation: ld-flip 2s infinite; +} +@keyframes ld-flip-v { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateX(0deg) rotateY(0deg); + transform: rotateX(0deg) rotateY(0deg); + } + 50% { + -webkit-transform: rotateX(180deg) rotateY(0deg); + transform: rotateX(180deg) rotateY(0deg); + } + 100% { + -webkit-transform: rotateX(0deg) rotateY(0deg); + transform: rotateX(0deg) rotateY(0deg); + } +} +@-webkit-keyframes ld-flip-v { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateX(0deg) rotateY(0deg); + transform: rotateX(0deg) rotateY(0deg); + } + 50% { + -webkit-transform: rotateX(180deg) rotateY(0deg); + transform: rotateX(180deg) rotateY(0deg); + } + 100% { + -webkit-transform: rotateX(0deg) rotateY(0deg); + transform: rotateX(0deg) rotateY(0deg); + } +} +.ld.ld-flip-v { + -webkit-animation: ld-flip-v 1s infinite; + animation: ld-flip-v 1s infinite; +} +@keyframes ld-flip-h { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateY(0deg) rotateX(0deg); + transform: rotateY(0deg) rotateX(0deg); + } + 50% { + -webkit-transform: rotateY(180deg) rotateX(0deg); + transform: rotateY(180deg) rotateX(0deg); + } + 100% { + -webkit-transform: rotateY(0deg) rotateX(0deg); + transform: rotateY(0deg) rotateX(0deg); + } +} +@-webkit-keyframes ld-flip-h { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateY(0deg) rotateX(0deg); + transform: rotateY(0deg) rotateX(0deg); + } + 50% { + -webkit-transform: rotateY(180deg) rotateX(0deg); + transform: rotateY(180deg) rotateX(0deg); + } + 100% { + -webkit-transform: rotateY(0deg) rotateX(0deg); + transform: rotateY(0deg) rotateX(0deg); + } +} +.ld.ld-flip-h { + -webkit-animation: ld-flip-h 1s infinite; + animation: ld-flip-h 1s infinite; +} +@keyframes ld-coin-v { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateX(0deg); + transform: rotateX(0deg); + } + 50% { + -webkit-transform: rotateX(1800deg); + transform: rotateX(1800deg); + } + 100% { + -webkit-transform: rotateX(3600deg); + transform: rotateX(3600deg); + } +} +@-webkit-keyframes ld-coin-v { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateX(0deg); + transform: rotateX(0deg); + } + 50% { + -webkit-transform: rotateX(1800deg); + transform: rotateX(1800deg); + } + 100% { + -webkit-transform: rotateX(3600deg); + transform: rotateX(3600deg); + } +} +.ld.ld-coin-v { + -webkit-animation: ld-coin-v 2s infinite; + animation: ld-coin-v 2s infinite; +} +@keyframes ld-coin-h { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateY(0deg); + transform: rotateY(0deg); + } + 50% { + -webkit-transform: rotateY(1800deg); + transform: rotateY(1800deg); + } + 100% { + -webkit-transform: rotateY(3600deg); + transform: rotateY(3600deg); + } +} +@-webkit-keyframes ld-coin-h { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: rotateY(0deg); + transform: rotateY(0deg); + } + 50% { + -webkit-transform: rotateY(1800deg); + transform: rotateY(1800deg); + } + 100% { + -webkit-transform: rotateY(3600deg); + transform: rotateY(3600deg); + } +} +.ld.ld-coin-h { + -webkit-animation: ld-coin-h 2s infinite; + animation: ld-coin-h 2s infinite; +} +@keyframes ld-heartbeat { + 0% { + -webkit-transform: scale(1.05); + transform: scale(1.05); + } + 5% { + -webkit-transform: scale(1.25); + transform: scale(1.25); + } + 39% { + -webkit-transform: scale(0.9); + transform: scale(0.9); + } + 45% { + -webkit-transform: scale(1.15); + transform: scale(1.15); + } + 60% { + -webkit-transform: scale(1.05); + transform: scale(1.05); + } + 100% { + -webkit-transform: scale(1); + transform: scale(1); + } +} +@-webkit-keyframes ld-heartbeat { + 0% { + -webkit-transform: scale(1.05); + transform: scale(1.05); + } + 5% { + -webkit-transform: scale(1.25); + transform: scale(1.25); + } + 39% { + -webkit-transform: scale(0.9); + transform: scale(0.9); + } + 45% { + -webkit-transform: scale(1.15); + transform: scale(1.15); + } + 60% { + -webkit-transform: scale(1.05); + transform: scale(1.05); + } + 100% { + -webkit-transform: scale(1); + transform: scale(1); + } +} +.ld.ld-heartbeat { + -webkit-animation: ld-heartbeat 0.8s infinite cubic-bezier(0.215, 0.61, 0.355, 1); + animation: ld-heartbeat 0.8s infinite cubic-bezier(0.215, 0.61, 0.355, 1); +} +@keyframes ld-radio { + 0% { + animation-timing-function: cubic-bezier(0.3, 0.27, 0.13, 1); + } + 0% { + -webkit-transform: scale(0.8); + transform: scale(0.8); + opacity: 0; + } + 5% { + -webkit-transform: scale(1); + transform: scale(1); + opacity: 1; + } + 100% { + -webkit-transform: scale(1.5); + transform: scale(1.5); + opacity: 0; + } +} +@-webkit-keyframes ld-radio { + 0% { + animation-timing-function: cubic-bezier(0.3, 0.27, 0.13, 1); + } + 0% { + -webkit-transform: scale(0.8); + transform: scale(0.8); + opacity: 0; + } + 5% { + -webkit-transform: scale(1); + transform: scale(1); + opacity: 1; + } + 100% { + -webkit-transform: scale(1.5); + transform: scale(1.5); + opacity: 0; + } +} +.ld.ld-radio { + position: relative; + display: inline-block; + margin: 0; + padding: 0; +} +.ld.ld-radio:after { + -webkit-animation: ld-radio 1s infinite; + animation: ld-radio 1s infinite; + content: " "; + display: block; + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + border: 6px solid #000; + border-radius: 50%; + background: none; +} +.ld.ld-radio.square:after { + border-radius: 0; +} +@keyframes ld-rotate { + 0%, 33%, 66%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 16%, 50%, 83% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: skewX(0deg) skewY(0deg) scaleX(2) scaleY(0.5); + transform: skewX(0deg) skewY(0deg) scaleX(2) scaleY(0.5); + } + 16% { + -webkit-transform: skewX(45deg) skewY(0deg) scaleX(1) scaleY(1); + transform: skewX(45deg) skewY(0deg) scaleX(1) scaleY(1); + } + 33% { + -webkit-transform: skewX(0deg) skewY(45deg) scaleX(1) scaleY(1); + transform: skewX(0deg) skewY(45deg) scaleX(1) scaleY(1); + } + 50% { + -webkit-transform: skewX(0deg) skewY(0deg) scaleX(0.5) scaleY(2); + transform: skewX(0deg) skewY(0deg) scaleX(0.5) scaleY(2); + } + 66% { + -webkit-transform: skewX(0deg) skewY(-45deg) scaleX(1) scaleY(1); + transform: skewX(0deg) skewY(-45deg) scaleX(1) scaleY(1); + } + 83% { + -webkit-transform: skewX(-45deg) skewY(0deg) scaleX(1) scaleY(1); + transform: skewX(-45deg) skewY(0deg) scaleX(1) scaleY(1); + } + 100% { + -webkit-transform: skewX(0deg) skewY(0deg) scaleX(2) scaleY(0.5); + transform: skewX(0deg) skewY(0deg) scaleX(2) scaleY(0.5); + } +} +@-webkit-keyframes ld-rotate { + 0%, 33%, 66%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 16%, 50%, 83% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: skewX(0deg) skewY(0deg) scaleX(2) scaleY(0.5); + transform: skewX(0deg) skewY(0deg) scaleX(2) scaleY(0.5); + } + 16% { + -webkit-transform: skewX(45deg) skewY(0deg) scaleX(1) scaleY(1); + transform: skewX(45deg) skewY(0deg) scaleX(1) scaleY(1); + } + 33% { + -webkit-transform: skewX(0deg) skewY(45deg) scaleX(1) scaleY(1); + transform: skewX(0deg) skewY(45deg) scaleX(1) scaleY(1); + } + 50% { + -webkit-transform: skewX(0deg) skewY(0deg) scaleX(0.5) scaleY(2); + transform: skewX(0deg) skewY(0deg) scaleX(0.5) scaleY(2); + } + 66% { + -webkit-transform: skewX(0deg) skewY(-45deg) scaleX(1) scaleY(1); + transform: skewX(0deg) skewY(-45deg) scaleX(1) scaleY(1); + } + 83% { + -webkit-transform: skewX(-45deg) skewY(0deg) scaleX(1) scaleY(1); + transform: skewX(-45deg) skewY(0deg) scaleX(1) scaleY(1); + } + 100% { + -webkit-transform: skewX(0deg) skewY(0deg) scaleX(2) scaleY(0.5); + transform: skewX(0deg) skewY(0deg) scaleX(2) scaleY(0.5); + } +} +.ld.ld-rotate { + -webkit-animation: ld-rotate 1s infinite; + animation: ld-rotate 1s infinite; +} +@keyframes ld-rubber { + 0% { + -webkit-transform: scale(1, 1); + transform: scale(1, 1); + } + 20% { + -webkit-transform: scale(1.5, 1); + transform: scale(1.5, 1); + } + 30% { + -webkit-transform: scale(0.8, 1); + transform: scale(0.8, 1); + } + 40% { + -webkit-transform: scale(1.3, 1); + transform: scale(1.3, 1); + } + 50% { + -webkit-transform: scale(0.85, 1); + transform: scale(0.85, 1); + } + 60% { + -webkit-transform: scale(1.2, 1); + transform: scale(1.2, 1); + } + 70% { + -webkit-transform: scale(0.9, 1); + transform: scale(0.9, 1); + } + 80% { + -webkit-transform: scale(1.1, 1); + transform: scale(1.1, 1); + } + 90% { + -webkit-transform: scale(0.95, 1); + transform: scale(0.95, 1); + } + 100% { + -webkit-transform: scale(1, 1); + transform: scale(1, 1); + } +} +@-webkit-keyframes ld-rubber { + 0% { + -webkit-transform: scale(1, 1); + transform: scale(1, 1); + } + 20% { + -webkit-transform: scale(1.5, 1); + transform: scale(1.5, 1); + } + 30% { + -webkit-transform: scale(0.8, 1); + transform: scale(0.8, 1); + } + 40% { + -webkit-transform: scale(1.3, 1); + transform: scale(1.3, 1); + } + 50% { + -webkit-transform: scale(0.85, 1); + transform: scale(0.85, 1); + } + 60% { + -webkit-transform: scale(1.2, 1); + transform: scale(1.2, 1); + } + 70% { + -webkit-transform: scale(0.9, 1); + transform: scale(0.9, 1); + } + 80% { + -webkit-transform: scale(1.1, 1); + transform: scale(1.1, 1); + } + 90% { + -webkit-transform: scale(0.95, 1); + transform: scale(0.95, 1); + } + 100% { + -webkit-transform: scale(1, 1); + transform: scale(1, 1); + } +} +.ld.ld-rubber { + -webkit-animation: ld-rubber 1s ease-out infinite; + animation: ld-rubber 1s ease-out infinite; +} +@keyframes ld-shadow { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 0.5, 1); + } + 50% { + animation-timing-function: cubic-bezier(0.5, 0, 0.5, 1); + } + 0% { + box-shadow: 0 0 0 0 rgba(0,0,0,0.2); + } + 50% { + box-shadow: 0 0 0 10px rgba(0,0,0,0.9); + } + 100% { + box-shadow: 0 0 0 0 rgba(0,0,0,0.2); + } +} +@-webkit-keyframes ld-shadow { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 0.5, 1); + } + 50% { + animation-timing-function: cubic-bezier(0.5, 0, 0.5, 1); + } + 0% { + box-shadow: 0 0 0 0 rgba(0,0,0,0.2); + } + 50% { + box-shadow: 0 0 0 10px rgba(0,0,0,0.9); + } + 100% { + box-shadow: 0 0 0 0 rgba(0,0,0,0.2); + } +} +.ld.ld-shadow { + -webkit-animation: ld-shadow 1s infinite; + animation: ld-shadow 1s infinite; + border-radius: 50%; +} +@keyframes ld-shadow-a { + 0% { + box-shadow: 3px 0px 0 6px rgba(0,0,0,0.5); + } + 8.33% { + box-shadow: 3px 1px 0 6px rgba(0,0,0,0.5); + } + 16.67% { + box-shadow: 2px 3px 0 6px rgba(0,0,0,0.5); + } + 25% { + box-shadow: 0px 3px 0 6px rgba(0,0,0,0.5); + } + 33.33% { + box-shadow: -1px 3px 0 6px rgba(0,0,0,0.5); + } + 41.67% { + box-shadow: -3px 1px 0 6px rgba(0,0,0,0.5); + } + 50% { + box-shadow: -3px 0px 0 6px rgba(0,0,0,0.5); + } + 58.33% { + box-shadow: -3px -1px 0 6px rgba(0,0,0,0.5); + } + 66.67% { + box-shadow: -2px -3px 0 6px rgba(0,0,0,0.5); + } + 75% { + box-shadow: 0px -3px 0 6px rgba(0,0,0,0.5); + } + 83.33% { + box-shadow: 2px -3px 0 6px rgba(0,0,0,0.5); + } + 91.67% { + box-shadow: 3px -2px 0 6px rgba(0,0,0,0.5); + } + 100% { + box-shadow: 3px 0px 0 6px rgba(0,0,0,0.5); + } +} +@-webkit-keyframes ld-shadow-a { + 0% { + box-shadow: 3px 0px 0 6px rgba(0,0,0,0.5); + } + 8.33% { + box-shadow: 3px 1px 0 6px rgba(0,0,0,0.5); + } + 16.67% { + box-shadow: 2px 3px 0 6px rgba(0,0,0,0.5); + } + 25% { + box-shadow: 0px 3px 0 6px rgba(0,0,0,0.5); + } + 33.33% { + box-shadow: -1px 3px 0 6px rgba(0,0,0,0.5); + } + 41.67% { + box-shadow: -3px 1px 0 6px rgba(0,0,0,0.5); + } + 50% { + box-shadow: -3px 0px 0 6px rgba(0,0,0,0.5); + } + 58.33% { + box-shadow: -3px -1px 0 6px rgba(0,0,0,0.5); + } + 66.67% { + box-shadow: -2px -3px 0 6px rgba(0,0,0,0.5); + } + 75% { + box-shadow: 0px -3px 0 6px rgba(0,0,0,0.5); + } + 83.33% { + box-shadow: 2px -3px 0 6px rgba(0,0,0,0.5); + } + 91.67% { + box-shadow: 3px -2px 0 6px rgba(0,0,0,0.5); + } + 100% { + box-shadow: 3px 0px 0 6px rgba(0,0,0,0.5); + } +} +.ld.ld-shadow-a { + -webkit-animation: ld-shadow-a 0.5s infinite; + animation: ld-shadow-a 0.5s infinite; + box-shadow: 3px 0px 0 6px rgba(0,0,0,0.5); + border-radius: 50%; +} +@keyframes ld-skew { + 0%, 50%, 100% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 25%, 75% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 0% { + -webkit-transform: skewX(20deg) scale(1); + transform: skewX(20deg) scale(1); + } + 25% { + -webkit-transform: skewX(0deg) scale(0.9); + transform: skewX(0deg) scale(0.9); + } + 50% { + -webkit-transform: skewX(-20deg) scale(1); + transform: skewX(-20deg) scale(1); + } + 75% { + -webkit-transform: skewX(0deg) scale(0.9); + transform: skewX(0deg) scale(0.9); + } + 100% { + -webkit-transform: skewX(20deg) scale(1); + transform: skewX(20deg) scale(1); + } +} +@-webkit-keyframes ld-skew { + 0%, 50%, 100% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 25%, 75% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 0% { + -webkit-transform: skewX(20deg) scale(1); + transform: skewX(20deg) scale(1); + } + 25% { + -webkit-transform: skewX(0deg) scale(0.9); + transform: skewX(0deg) scale(0.9); + } + 50% { + -webkit-transform: skewX(-20deg) scale(1); + transform: skewX(-20deg) scale(1); + } + 75% { + -webkit-transform: skewX(0deg) scale(0.9); + transform: skewX(0deg) scale(0.9); + } + 100% { + -webkit-transform: skewX(20deg) scale(1); + transform: skewX(20deg) scale(1); + } +} +.ld.ld-skew { + -webkit-animation: ld-skew 1s infinite; + animation: ld-skew 1s infinite; +} +@keyframes ld-spin { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); + } + 50% { + -webkit-transform: rotate(180deg); + transform: rotate(180deg); + animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +@-webkit-keyframes ld-spin { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); + } + 50% { + -webkit-transform: rotate(180deg); + transform: rotate(180deg); + animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); + } + 100% { + -webkit-transform: rotate(360deg); + transform: rotate(360deg); + } +} +.ld.ld-spin { + -webkit-animation: ld-spin 1s infinite; + animation: ld-spin 1s infinite; +} +@keyframes ld-spin-fast { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); + } + 50% { + -webkit-transform: rotate(900deg); + transform: rotate(900deg); + animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); + } + 100% { + -webkit-transform: rotate(1800deg); + transform: rotate(1800deg); + } +} +@-webkit-keyframes ld-spin-fast { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19); + } + 50% { + -webkit-transform: rotate(900deg); + transform: rotate(900deg); + animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); + } + 100% { + -webkit-transform: rotate(1800deg); + transform: rotate(1800deg); + } +} +.ld.ld-spin-fast { + -webkit-animation: ld-spin-fast 1s infinite; + animation: ld-spin-fast 1s infinite; +} +@keyframes ld-squeeze { + 0% { + -webkit-transform: scale(1, 0.5); + transform: scale(1, 0.5); + } + 50% { + -webkit-transform: scale(0.5, 1); + transform: scale(0.5, 1); + } + 100% { + -webkit-transform: scale(1, 0.5); + transform: scale(1, 0.5); + } +} +@-webkit-keyframes ld-squeeze { + 0% { + -webkit-transform: scale(1, 0.5); + transform: scale(1, 0.5); + } + 50% { + -webkit-transform: scale(0.5, 1); + transform: scale(0.5, 1); + } + 100% { + -webkit-transform: scale(1, 0.5); + transform: scale(1, 0.5); + } +} +.ld.ld-squeeze { + -webkit-animation: ld-squeeze 0.8s infinite cubic-bezier(0.215, 0.61, 0.355, 1); + animation: ld-squeeze 0.8s infinite cubic-bezier(0.215, 0.61, 0.355, 1); +} +@keyframes ld-surprise { + 0% { + -webkit-transform: skewX(0deg) scale(1); + transform: skewX(0deg) scale(1); + } + 10% { + -webkit-transform: skewX(-15deg) scale(0.8); + transform: skewX(-15deg) scale(0.8); + } + 20% { + -webkit-transform: skewX(-15deg) scale(0.8); + transform: skewX(-15deg) scale(0.8); + } + 30% { + -webkit-transform: skewX(15deg) scale(1.3); + transform: skewX(15deg) scale(1.3); + } + 40% { + -webkit-transform: skewX(-15deg) scale(1.3); + transform: skewX(-15deg) scale(1.3); + } + 50% { + -webkit-transform: skewX(15deg) scale(1.3); + transform: skewX(15deg) scale(1.3); + } + 60% { + -webkit-transform: skewX(-15deg) scale(1.3); + transform: skewX(-15deg) scale(1.3); + } + 70% { + -webkit-transform: skewX(15deg) scale(1.3); + transform: skewX(15deg) scale(1.3); + } + 80% { + -webkit-transform: skewX(-15deg) scale(1.3); + transform: skewX(-15deg) scale(1.3); + } + 90% { + -webkit-transform: skewX(15deg) scale(1.3); + transform: skewX(15deg) scale(1.3); + } + 100% { + -webkit-transform: skewX(-15deg) scale(1.3); + transform: skewX(-15deg) scale(1.3); + } +} +@-webkit-keyframes ld-surprise { + 0% { + -webkit-transform: skewX(0deg) scale(1); + transform: skewX(0deg) scale(1); + } + 10% { + -webkit-transform: skewX(-15deg) scale(0.8); + transform: skewX(-15deg) scale(0.8); + } + 20% { + -webkit-transform: skewX(-15deg) scale(0.8); + transform: skewX(-15deg) scale(0.8); + } + 30% { + -webkit-transform: skewX(15deg) scale(1.3); + transform: skewX(15deg) scale(1.3); + } + 40% { + -webkit-transform: skewX(-15deg) scale(1.3); + transform: skewX(-15deg) scale(1.3); + } + 50% { + -webkit-transform: skewX(15deg) scale(1.3); + transform: skewX(15deg) scale(1.3); + } + 60% { + -webkit-transform: skewX(-15deg) scale(1.3); + transform: skewX(-15deg) scale(1.3); + } + 70% { + -webkit-transform: skewX(15deg) scale(1.3); + transform: skewX(15deg) scale(1.3); + } + 80% { + -webkit-transform: skewX(-15deg) scale(1.3); + transform: skewX(-15deg) scale(1.3); + } + 90% { + -webkit-transform: skewX(15deg) scale(1.3); + transform: skewX(15deg) scale(1.3); + } + 100% { + -webkit-transform: skewX(-15deg) scale(1.3); + transform: skewX(-15deg) scale(1.3); + } +} +.ld.ld-surprise { + -webkit-animation: ld-surprise 1s infinite linear; + animation: ld-surprise 1s infinite linear; +} +@keyframes ld-tick { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + } + 20% { + -webkit-transform: rotate(-30deg); + transform: rotate(-30deg); + } + 30% { + -webkit-transform: rotate(30deg); + transform: rotate(30deg); + } + 40% { + -webkit-transform: rotate(-21deg); + transform: rotate(-21deg); + } + 50% { + -webkit-transform: rotate(15deg); + transform: rotate(15deg); + } + 60% { + -webkit-transform: rotate(-10deg); + transform: rotate(-10deg); + } + 70% { + -webkit-transform: rotate(6deg); + transform: rotate(6deg); + } + 80% { + -webkit-transform: rotate(-2deg); + transform: rotate(-2deg); + } + 90% { + -webkit-transform: rotate(1deg); + transform: rotate(1deg); + } + 100% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } +} +@-webkit-keyframes ld-tick { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); + } + 20% { + -webkit-transform: rotate(-30deg); + transform: rotate(-30deg); + } + 30% { + -webkit-transform: rotate(30deg); + transform: rotate(30deg); + } + 40% { + -webkit-transform: rotate(-21deg); + transform: rotate(-21deg); + } + 50% { + -webkit-transform: rotate(15deg); + transform: rotate(15deg); + } + 60% { + -webkit-transform: rotate(-10deg); + transform: rotate(-10deg); + } + 70% { + -webkit-transform: rotate(6deg); + transform: rotate(6deg); + } + 80% { + -webkit-transform: rotate(-2deg); + transform: rotate(-2deg); + } + 90% { + -webkit-transform: rotate(1deg); + transform: rotate(1deg); + } + 100% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } +} +.ld.ld-tick { + -webkit-animation: ld-tick 1s ease-out infinite; + animation: ld-tick 1s ease-out infinite; +} +@keyframes ld-vortex-in { + 0% { + -webkit-transform: rotate(1800deg) scale(3); + transform: rotate(1800deg) scale(3); + opacity: 0; + } + 60% { + -webkit-transform: rotate(0deg) scale(1); + transform: rotate(0deg) scale(1); + opacity: 1; + } + 100% { + opacity: 0; + } +} +@-webkit-keyframes ld-vortex-in { + 0% { + -webkit-transform: rotate(1800deg) scale(3); + transform: rotate(1800deg) scale(3); + opacity: 0; + } + 60% { + -webkit-transform: rotate(0deg) scale(1); + transform: rotate(0deg) scale(1); + opacity: 1; + } + 100% { + opacity: 0; + } +} +.ld.ld-vortex-in { + -webkit-animation: ld-vortex-in 2s infinite; + animation: ld-vortex-in 2s infinite; + animation-timing-function: cubic-bezier(0.3, 0, 1, 0.7); +} +@keyframes ld-vortex-out { + 0% { + -webkit-transform: rotate(0deg) scale(0); + transform: rotate(0deg) scale(0); + opacity: 1; + } + 60% { + -webkit-transform: rotate(1800deg) scale(1); + transform: rotate(1800deg) scale(1); + opacity: 1; + } + 100% { + -webkit-transform: rotate(1800deg) scale(1); + transform: rotate(1800deg) scale(1); + opacity: 0; + } +} +@-webkit-keyframes ld-vortex-out { + 0% { + -webkit-transform: rotate(0deg) scale(0); + transform: rotate(0deg) scale(0); + opacity: 1; + } + 60% { + -webkit-transform: rotate(1800deg) scale(1); + transform: rotate(1800deg) scale(1); + opacity: 1; + } + 100% { + -webkit-transform: rotate(1800deg) scale(1); + transform: rotate(1800deg) scale(1); + opacity: 0; + } +} +.ld.ld-vortex-out { + -webkit-animation: ld-vortex-out 2s infinite; + animation: ld-vortex-out 2s infinite; + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); +} +@keyframes ld-wrench { + 20%, 36%, 70%, 86% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + 0%, 50%, 100% { + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + } +} +@-webkit-keyframes ld-wrench { + 20%, 36%, 70%, 86% { + -webkit-transform: rotate(0deg); + transform: rotate(0deg); + } + 0%, 50%, 100% { + -webkit-transform: rotate(45deg); + transform: rotate(45deg); + } +} +.ld.ld-wrench { + -webkit-animation: ld-wrench 1s infinite; + animation: ld-wrench 1s infinite; +} +@keyframes ld-pulse { + 0% { + -webkit-transform: scale(1.1); + transform: scale(1.1); + } + 50% { + -webkit-transform: scale(0.9); + transform: scale(0.9); + } + 51% { + -webkit-transform: scale(1.1); + transform: scale(1.1); + } + 100% { + -webkit-transform: scale(0.9); + transform: scale(0.9); + } +} +@-webkit-keyframes ld-pulse { + 0% { + -webkit-transform: scale(1.1); + transform: scale(1.1); + } + 50% { + -webkit-transform: scale(0.9); + transform: scale(0.9); + } + 51% { + -webkit-transform: scale(1.1); + transform: scale(1.1); + } + 100% { + -webkit-transform: scale(0.9); + transform: scale(0.9); + } +} +.ld.ld-pulse { + -webkit-animation: ld-pulse 0.8s infinite cubic-bezier(0.215, 0.61, 0.355, 1); + animation: ld-pulse 0.8s infinite cubic-bezier(0.215, 0.61, 0.355, 1); +} +@keyframes ld-bounce { + 0%, 90% { + animation-timing-function: linear; + } + 10% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 50% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 0% { + -webkit-transform: translate(0%, 30%) scaleY(0.5); + transform: translate(0%, 30%) scaleY(0.5); + } + 10% { + -webkit-transform: translate(0%, 5%) scaleY(1.1); + transform: translate(0%, 5%) scaleY(1.1); + } + 50% { + -webkit-transform: translate(0%, -37%) scaleY(1.1); + transform: translate(0%, -37%) scaleY(1.1); + } + 90% { + -webkit-transform: translate(0%, 5%) scaleY(1.1); + transform: translate(0%, 5%) scaleY(1.1); + } + 100% { + -webkit-transform: translate(0%, 30%) scaleY(0.5); + transform: translate(0%, 30%) scaleY(0.5); + } +} +@-webkit-keyframes ld-bounce { + 0%, 90% { + animation-timing-function: linear; + } + 10% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 50% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 0% { + -webkit-transform: translate(0%, 30%) scaleY(0.5); + transform: translate(0%, 30%) scaleY(0.5); + } + 10% { + -webkit-transform: translate(0%, 5%) scaleY(1.1); + transform: translate(0%, 5%) scaleY(1.1); + } + 50% { + -webkit-transform: translate(0%, -37%) scaleY(1.1); + transform: translate(0%, -37%) scaleY(1.1); + } + 90% { + -webkit-transform: translate(0%, 5%) scaleY(1.1); + transform: translate(0%, 5%) scaleY(1.1); + } + 100% { + -webkit-transform: translate(0%, 30%) scaleY(0.5); + transform: translate(0%, 30%) scaleY(0.5); + } +} +.ld.ld-bounce { + -webkit-animation: ld-bounce 1s infinite; + animation: ld-bounce 1s infinite; +} +@keyframes ld-bounce-rtl { + 0% { + -webkit-transform: translate(160%, -40%); + transform: translate(160%, -40%); + } + 12.5% { + -webkit-transform: translate(120%, -23%); + transform: translate(120%, -23%); + } + 25% { + -webkit-transform: translate(80%, 0%); + transform: translate(80%, 0%); + } + 37.5% { + -webkit-transform: translate(50%, -23%); + transform: translate(50%, -23%); + } + 50% { + -webkit-transform: translate(0%, -40%); + transform: translate(0%, -40%); + } + 62.5% { + -webkit-transform: translate(-50%, -23%); + transform: translate(-50%, -23%); + } + 75% { + -webkit-transform: translate(-80%, 0%); + transform: translate(-80%, 0%); + } + 87.5% { + -webkit-transform: translate(-120%, -23%); + transform: translate(-120%, -23%); + } + 100% { + -webkit-transform: translate(-160%, -40%); + transform: translate(-160%, -40%); + } +} +@-webkit-keyframes ld-bounce-rtl { + 0% { + -webkit-transform: translate(160%, -40%); + transform: translate(160%, -40%); + } + 12.5% { + -webkit-transform: translate(120%, -23%); + transform: translate(120%, -23%); + } + 25% { + -webkit-transform: translate(80%, 0%); + transform: translate(80%, 0%); + } + 37.5% { + -webkit-transform: translate(50%, -23%); + transform: translate(50%, -23%); + } + 50% { + -webkit-transform: translate(0%, -40%); + transform: translate(0%, -40%); + } + 62.5% { + -webkit-transform: translate(-50%, -23%); + transform: translate(-50%, -23%); + } + 75% { + -webkit-transform: translate(-80%, 0%); + transform: translate(-80%, 0%); + } + 87.5% { + -webkit-transform: translate(-120%, -23%); + transform: translate(-120%, -23%); + } + 100% { + -webkit-transform: translate(-160%, -40%); + transform: translate(-160%, -40%); + } +} +.ld.ld-bounce-rtl { + -webkit-animation: ld-bounce-rtl 1s infinite linear; + animation: ld-bounce-rtl 1s infinite linear; +} +@keyframes ld-bounce-ltr { + 0% { + -webkit-transform: translate(-160%, -40%); + transform: translate(-160%, -40%); + } + 12.5% { + -webkit-transform: translate(-120%, -23%); + transform: translate(-120%, -23%); + } + 25% { + -webkit-transform: translate(-100%, 0%); + transform: translate(-100%, 0%); + } + 37.5% { + -webkit-transform: translate(-50%, -23%); + transform: translate(-50%, -23%); + } + 50% { + -webkit-transform: translate(0%, -40%); + transform: translate(0%, -40%); + } + 62.5% { + -webkit-transform: translate(50%, -23%); + transform: translate(50%, -23%); + } + 75% { + -webkit-transform: translate(100%, 0%); + transform: translate(100%, 0%); + } + 87.5% { + -webkit-transform: translate(120%, -23%); + transform: translate(120%, -23%); + } + 100% { + -webkit-transform: translate(160%, -40%); + transform: translate(160%, -40%); + } +} +@-webkit-keyframes ld-bounce-ltr { + 0% { + -webkit-transform: translate(-160%, -40%); + transform: translate(-160%, -40%); + } + 12.5% { + -webkit-transform: translate(-120%, -23%); + transform: translate(-120%, -23%); + } + 25% { + -webkit-transform: translate(-100%, 0%); + transform: translate(-100%, 0%); + } + 37.5% { + -webkit-transform: translate(-50%, -23%); + transform: translate(-50%, -23%); + } + 50% { + -webkit-transform: translate(0%, -40%); + transform: translate(0%, -40%); + } + 62.5% { + -webkit-transform: translate(50%, -23%); + transform: translate(50%, -23%); + } + 75% { + -webkit-transform: translate(100%, 0%); + transform: translate(100%, 0%); + } + 87.5% { + -webkit-transform: translate(120%, -23%); + transform: translate(120%, -23%); + } + 100% { + -webkit-transform: translate(160%, -40%); + transform: translate(160%, -40%); + } +} +.ld.ld-bounce-ltr { + -webkit-animation: ld-bounce-ltr 1s infinite linear; + animation: ld-bounce-ltr 1s infinite linear; +} +@keyframes ld-bounce-a-px { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 12.5%, 37.5%, 62.5%, 87.5% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 0% { + -webkit-transform: translate(0%, 0%); + transform: translate(0%, 0%); + } + 12.5% { + -webkit-transform: translate(5%, -28%); + transform: translate(5%, -28%); + } + 25% { + -webkit-transform: translate(10%, 0%); + transform: translate(10%, 0%); + } + 37.5% { + -webkit-transform: translate(5%, -28%); + transform: translate(5%, -28%); + } + 50% { + -webkit-transform: translate(0%, 0%); + transform: translate(0%, 0%); + } + 62.5% { + -webkit-transform: translate(-5%, -28%); + transform: translate(-5%, -28%); + } + 75% { + -webkit-transform: translate(-10%, 0%); + transform: translate(-10%, 0%); + } + 87.5% { + -webkit-transform: translate(-5%, -28%); + transform: translate(-5%, -28%); + } + 100% { + -webkit-transform: translate(0%, 0%); + transform: translate(0%, 0%); + } +} +@-webkit-keyframes ld-bounce-a-px { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 12.5%, 37.5%, 62.5%, 87.5% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 0% { + -webkit-transform: translate(0%, 0%); + transform: translate(0%, 0%); + } + 12.5% { + -webkit-transform: translate(5%, -28%); + transform: translate(5%, -28%); + } + 25% { + -webkit-transform: translate(10%, 0%); + transform: translate(10%, 0%); + } + 37.5% { + -webkit-transform: translate(5%, -28%); + transform: translate(5%, -28%); + } + 50% { + -webkit-transform: translate(0%, 0%); + transform: translate(0%, 0%); + } + 62.5% { + -webkit-transform: translate(-5%, -28%); + transform: translate(-5%, -28%); + } + 75% { + -webkit-transform: translate(-10%, 0%); + transform: translate(-10%, 0%); + } + 87.5% { + -webkit-transform: translate(-5%, -28%); + transform: translate(-5%, -28%); + } + 100% { + -webkit-transform: translate(0%, 0%); + transform: translate(0%, 0%); + } +} +.ld.ld-bounce-a-px { + -webkit-animation: ld-bounce-a-px 2s infinite; + animation: ld-bounce-a-px 2s infinite; +} +@keyframes ld-float { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: linear; + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + box-shadow: 0 0 0 rgba(0,0,0,0.3); + } + 30% { + -webkit-transform: translate(0, -10%); + transform: translate(0, -10%); + box-shadow: 0 5px 5px rgba(0,0,0,0.3); + } + 50% { + -webkit-transform: translate(0, -10%); + transform: translate(0, -10%); + box-shadow: 0 5px 5px rgba(0,0,0,0.3); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + box-shadow: 0 0 0 rgba(0,0,0,0.3); + } +} +@-webkit-keyframes ld-float { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: linear; + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + box-shadow: 0 0 0 rgba(0,0,0,0.3); + } + 30% { + -webkit-transform: translate(0, -10%); + transform: translate(0, -10%); + box-shadow: 0 5px 5px rgba(0,0,0,0.3); + } + 50% { + -webkit-transform: translate(0, -10%); + transform: translate(0, -10%); + box-shadow: 0 5px 5px rgba(0,0,0,0.3); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + box-shadow: 0 0 0 rgba(0,0,0,0.3); + } +} +.ld.ld-float { + -webkit-animation: ld-float 1s infinite; + animation: ld-float 1s infinite; +} +@keyframes ld-hit { + 0% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + -webkit-transform: scale(0) translate(0, 0) skewX(0); + transform: scale(0) translate(0, 0) skewX(0); + } + 20% { + -webkit-transform: scale(1) translate(0, 0) skewX(20deg); + transform: scale(1) translate(0, 0) skewX(20deg); + } + 50% { + animation-timing-function: cubic-bezier(1, 0, 1, 0.5); + -webkit-transform: scale(1) translate(0, 0) skewX(20deg); + transform: scale(1) translate(0, 0) skewX(20deg); + } + 100% { + -webkit-transform: scale(1) translate(0, 200%) skewX(20deg); + transform: scale(1) translate(0, 200%) skewX(20deg); + } +} +@-webkit-keyframes ld-hit { + 0% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + -webkit-transform: scale(0) translate(0, 0) skewX(0); + transform: scale(0) translate(0, 0) skewX(0); + } + 20% { + -webkit-transform: scale(1) translate(0, 0) skewX(20deg); + transform: scale(1) translate(0, 0) skewX(20deg); + } + 50% { + animation-timing-function: cubic-bezier(1, 0, 1, 0.5); + -webkit-transform: scale(1) translate(0, 0) skewX(20deg); + transform: scale(1) translate(0, 0) skewX(20deg); + } + 100% { + -webkit-transform: scale(1) translate(0, 200%) skewX(20deg); + transform: scale(1) translate(0, 200%) skewX(20deg); + } +} +.ld.ld-hit { + -webkit-animation: ld-hit 2s infinite; + animation: ld-hit 2s infinite; +} +@keyframes ld-jelly { + 0%, 16.6%, 33.3%, 50%, 66.6%, 83.3% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } + 16.6% { + -webkit-transform: translate(-30%, 0) skewX(30deg); + transform: translate(-30%, 0) skewX(30deg); + } + 33.3% { + -webkit-transform: translate(25%, 0) skewX(-20deg); + transform: translate(25%, 0) skewX(-20deg); + } + 50% { + -webkit-transform: translate(-12%, 0) skewX(10deg); + transform: translate(-12%, 0) skewX(10deg); + } + 66.6% { + -webkit-transform: translate(6%, 0) skewX(-5deg); + transform: translate(6%, 0) skewX(-5deg); + } + 83.3% { + -webkit-transform: translate(-2.5%, 0) skewX(2deg); + transform: translate(-2.5%, 0) skewX(2deg); + } + 100% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } +} +@-webkit-keyframes ld-jelly { + 0%, 16.6%, 33.3%, 50%, 66.6%, 83.3% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } + 16.6% { + -webkit-transform: translate(-30%, 0) skewX(30deg); + transform: translate(-30%, 0) skewX(30deg); + } + 33.3% { + -webkit-transform: translate(25%, 0) skewX(-20deg); + transform: translate(25%, 0) skewX(-20deg); + } + 50% { + -webkit-transform: translate(-12%, 0) skewX(10deg); + transform: translate(-12%, 0) skewX(10deg); + } + 66.6% { + -webkit-transform: translate(6%, 0) skewX(-5deg); + transform: translate(6%, 0) skewX(-5deg); + } + 83.3% { + -webkit-transform: translate(-2.5%, 0) skewX(2deg); + transform: translate(-2.5%, 0) skewX(2deg); + } + 100% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } +} +.ld.ld-jelly { + -webkit-animation: ld-jelly 1s infinite linear; + animation: ld-jelly 1s infinite linear; +} +@keyframes ld-jump { + 0%, 28%, 48%, 64%, 76%, 86%, 93%, 100% { + animation-timing-function: ease-out; + } + 14%, 38%, 56%, 70%, 81%, 90%, 97% { + animation-timing-function: ease-in; + } + 0% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 14% { + -webkit-transform: translateY(-27%); + transform: translateY(-27%); + } + 28% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 38% { + -webkit-transform: translateY(-20%); + transform: translateY(-20%); + } + 48% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 56% { + -webkit-transform: translateY(-16%); + transform: translateY(-16%); + } + 64% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 70% { + -webkit-transform: translateY(-12%); + transform: translateY(-12%); + } + 76% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 81% { + -webkit-transform: translateY(-7.5%); + transform: translateY(-7.5%); + } + 86% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 90% { + -webkit-transform: translateY(-3%); + transform: translateY(-3%); + } + 93% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 97% { + -webkit-transform: translateY(-1.5%); + transform: translateY(-1.5%); + } + 100% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } +} +@-webkit-keyframes ld-jump { + 0%, 28%, 48%, 64%, 76%, 86%, 93%, 100% { + animation-timing-function: ease-out; + } + 14%, 38%, 56%, 70%, 81%, 90%, 97% { + animation-timing-function: ease-in; + } + 0% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 14% { + -webkit-transform: translateY(-27%); + transform: translateY(-27%); + } + 28% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 38% { + -webkit-transform: translateY(-20%); + transform: translateY(-20%); + } + 48% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 56% { + -webkit-transform: translateY(-16%); + transform: translateY(-16%); + } + 64% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 70% { + -webkit-transform: translateY(-12%); + transform: translateY(-12%); + } + 76% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 81% { + -webkit-transform: translateY(-7.5%); + transform: translateY(-7.5%); + } + 86% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 90% { + -webkit-transform: translateY(-3%); + transform: translateY(-3%); + } + 93% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } + 97% { + -webkit-transform: translateY(-1.5%); + transform: translateY(-1.5%); + } + 100% { + -webkit-transform: translateY(0%); + transform: translateY(0%); + } +} +.ld.ld-jump { + -webkit-animation: ld-jump 1.5s ease-in infinite; + animation: ld-jump 1.5s ease-in infinite; +} +@keyframes ld-orbit { + 0% { + -webkit-transform: translate(30%, 0%) rotate(0deg); + transform: translate(30%, 0%) rotate(0deg); + } + 12.5% { + -webkit-transform: translate(21%, 21%) rotate(45deg); + transform: translate(21%, 21%) rotate(45deg); + } + 25% { + -webkit-transform: translate(0%, 30%) rotate(90deg); + transform: translate(0%, 30%) rotate(90deg); + } + 37.5% { + -webkit-transform: translate(-21%, 21%) rotate(135deg); + transform: translate(-21%, 21%) rotate(135deg); + } + 50% { + -webkit-transform: translate(-30%, 0%) rotate(180deg); + transform: translate(-30%, 0%) rotate(180deg); + } + 62.5% { + -webkit-transform: translate(-21%, -21%) rotate(225deg); + transform: translate(-21%, -21%) rotate(225deg); + } + 75% { + -webkit-transform: translate(0%, -30%) rotate(270deg); + transform: translate(0%, -30%) rotate(270deg); + } + 87.5% { + -webkit-transform: translate(21%, -21%) rotate(315deg); + transform: translate(21%, -21%) rotate(315deg); + } + 100% { + -webkit-transform: translate(30%, 0%) rotate(360deg); + transform: translate(30%, 0%) rotate(360deg); + } +} +@-webkit-keyframes ld-orbit { + 0% { + -webkit-transform: translate(30%, 0%) rotate(0deg); + transform: translate(30%, 0%) rotate(0deg); + } + 12.5% { + -webkit-transform: translate(21%, 21%) rotate(45deg); + transform: translate(21%, 21%) rotate(45deg); + } + 25% { + -webkit-transform: translate(0%, 30%) rotate(90deg); + transform: translate(0%, 30%) rotate(90deg); + } + 37.5% { + -webkit-transform: translate(-21%, 21%) rotate(135deg); + transform: translate(-21%, 21%) rotate(135deg); + } + 50% { + -webkit-transform: translate(-30%, 0%) rotate(180deg); + transform: translate(-30%, 0%) rotate(180deg); + } + 62.5% { + -webkit-transform: translate(-21%, -21%) rotate(225deg); + transform: translate(-21%, -21%) rotate(225deg); + } + 75% { + -webkit-transform: translate(0%, -30%) rotate(270deg); + transform: translate(0%, -30%) rotate(270deg); + } + 87.5% { + -webkit-transform: translate(21%, -21%) rotate(315deg); + transform: translate(21%, -21%) rotate(315deg); + } + 100% { + -webkit-transform: translate(30%, 0%) rotate(360deg); + transform: translate(30%, 0%) rotate(360deg); + } +} +.ld.ld-orbit { + -webkit-animation: ld-orbit 1s infinite linear; + animation: ld-orbit 1s infinite linear; +} +@keyframes ld-rush-rtl { + 0% { + -webkit-transform: translate(200%, 0) skewX(-45deg); + transform: translate(200%, 0) skewX(-45deg); + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 30% { + -webkit-transform: translate(-40%, 0) skewX(35deg); + transform: translate(-40%, 0) skewX(35deg); + } + 45% { + -webkit-transform: translate(20%, 0) skewX(-15deg); + transform: translate(20%, 0) skewX(-15deg); + } + 60% { + -webkit-transform: translate(-10%, 0) skewX(7deg); + transform: translate(-10%, 0) skewX(7deg); + } + 80% { + -webkit-transform: translate(0%, 0) skewX(0deg); + transform: translate(0%, 0) skewX(0deg); + } + 100% { + -webkit-transform: translate(-250%, 0) skewX(-45deg); + transform: translate(-250%, 0) skewX(-45deg); + } +} +@-webkit-keyframes ld-rush-rtl { + 0% { + -webkit-transform: translate(200%, 0) skewX(-45deg); + transform: translate(200%, 0) skewX(-45deg); + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 30% { + -webkit-transform: translate(-40%, 0) skewX(35deg); + transform: translate(-40%, 0) skewX(35deg); + } + 45% { + -webkit-transform: translate(20%, 0) skewX(-15deg); + transform: translate(20%, 0) skewX(-15deg); + } + 60% { + -webkit-transform: translate(-10%, 0) skewX(7deg); + transform: translate(-10%, 0) skewX(7deg); + } + 80% { + -webkit-transform: translate(0%, 0) skewX(0deg); + transform: translate(0%, 0) skewX(0deg); + } + 100% { + -webkit-transform: translate(-250%, 0) skewX(-45deg); + transform: translate(-250%, 0) skewX(-45deg); + } +} +.ld.ld-rush-rtl { + -webkit-animation: ld-rush-rtl 1.5s infinite linear; + animation: ld-rush-rtl 1.5s infinite linear; +} +@keyframes ld-rush-ltr { + 0% { + -webkit-transform: translate(-200%, 0) skewX(45deg); + transform: translate(-200%, 0) skewX(45deg); + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 30% { + -webkit-transform: translate(40%, 0) skewX(-35deg); + transform: translate(40%, 0) skewX(-35deg); + } + 45% { + -webkit-transform: translate(-20%, 0) skewX(15deg); + transform: translate(-20%, 0) skewX(15deg); + } + 60% { + -webkit-transform: translate(10%, 0) skewX(-7deg); + transform: translate(10%, 0) skewX(-7deg); + } + 80% { + -webkit-transform: translate(0%, 0) skewX(0deg); + transform: translate(0%, 0) skewX(0deg); + } + 100% { + -webkit-transform: translate(250%, 0) skewX(45deg); + transform: translate(250%, 0) skewX(45deg); + } +} +@-webkit-keyframes ld-rush-ltr { + 0% { + -webkit-transform: translate(-200%, 0) skewX(45deg); + transform: translate(-200%, 0) skewX(45deg); + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 30% { + -webkit-transform: translate(40%, 0) skewX(-35deg); + transform: translate(40%, 0) skewX(-35deg); + } + 45% { + -webkit-transform: translate(-20%, 0) skewX(15deg); + transform: translate(-20%, 0) skewX(15deg); + } + 60% { + -webkit-transform: translate(10%, 0) skewX(-7deg); + transform: translate(10%, 0) skewX(-7deg); + } + 80% { + -webkit-transform: translate(0%, 0) skewX(0deg); + transform: translate(0%, 0) skewX(0deg); + } + 100% { + -webkit-transform: translate(250%, 0) skewX(45deg); + transform: translate(250%, 0) skewX(45deg); + } +} +.ld.ld-rush-ltr { + -webkit-animation: ld-rush-ltr 1.5s infinite linear; + animation: ld-rush-ltr 1.5s infinite linear; +} +@keyframes ld-shake { + 0%, 16.6%, 33.3%, 50%, 66.6%, 83.3% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 16.6% { + -webkit-transform: translate(-35%, 0); + transform: translate(-35%, 0); + } + 33.3% { + -webkit-transform: translate(25%, 0); + transform: translate(25%, 0); + } + 50% { + -webkit-transform: translate(-12%, 0); + transform: translate(-12%, 0); + } + 66.6% { + -webkit-transform: translate(6%, 0); + transform: translate(6%, 0); + } + 83.3% { + -webkit-transform: translate(-2.5%, 0); + transform: translate(-2.5%, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-shake { + 0%, 16.6%, 33.3%, 50%, 66.6%, 83.3% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 16.6% { + -webkit-transform: translate(-35%, 0); + transform: translate(-35%, 0); + } + 33.3% { + -webkit-transform: translate(25%, 0); + transform: translate(25%, 0); + } + 50% { + -webkit-transform: translate(-12%, 0); + transform: translate(-12%, 0); + } + 66.6% { + -webkit-transform: translate(6%, 0); + transform: translate(6%, 0); + } + 83.3% { + -webkit-transform: translate(-2.5%, 0); + transform: translate(-2.5%, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-shake { + -webkit-animation: ld-shake 1s infinite linear; + animation: ld-shake 1s infinite linear; +} +@keyframes ld-slide-ltr { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(200%, 0); + transform: translate(200%, 0); + } + 50% { + -webkit-transform: translate(-200%, 0); + transform: translate(-200%, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-slide-ltr { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(200%, 0); + transform: translate(200%, 0); + } + 50% { + -webkit-transform: translate(-200%, 0); + transform: translate(-200%, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-slide-ltr { + -webkit-animation: ld-slide-ltr 1s infinite; + animation: ld-slide-ltr 1s infinite; +} +@keyframes ld-slide-rtl { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(-200%, 0); + transform: translate(-200%, 0); + } + 50% { + -webkit-transform: translate(200%, 0); + transform: translate(200%, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-slide-rtl { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(-200%, 0); + transform: translate(-200%, 0); + } + 50% { + -webkit-transform: translate(200%, 0); + transform: translate(200%, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-slide-rtl { + -webkit-animation: ld-slide-rtl 1s infinite; + animation: ld-slide-rtl 1s infinite; +} +@keyframes ld-slide-btt { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(0, -200%); + transform: translate(0, -200%); + } + 50% { + -webkit-transform: translate(0, 200%); + transform: translate(0, 200%); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-slide-btt { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(0, -200%); + transform: translate(0, -200%); + } + 50% { + -webkit-transform: translate(0, 200%); + transform: translate(0, 200%); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-slide-btt { + -webkit-animation: ld-slide-btt 1s infinite; + animation: ld-slide-btt 1s infinite; +} +@keyframes ld-slide-ttb { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(0, 200%); + transform: translate(0, 200%); + } + 50% { + -webkit-transform: translate(0, -200%); + transform: translate(0, -200%); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-slide-ttb { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(0, 200%); + transform: translate(0, 200%); + } + 50% { + -webkit-transform: translate(0, -200%); + transform: translate(0, -200%); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-slide-ttb { + -webkit-animation: ld-slide-ttb 1s infinite; + animation: ld-slide-ttb 1s infinite; +} +@keyframes ld-tremble { + 0% { + -webkit-transform: translate(1%, 1%); + transform: translate(1%, 1%); + } + 5% { + -webkit-transform: translate(0%, 1%); + transform: translate(0%, 1%); + } + 10% { + -webkit-transform: translate(1%, 2%); + transform: translate(1%, 2%); + } + 15% { + -webkit-transform: translate(2%, 1%); + transform: translate(2%, 1%); + } + 20% { + -webkit-transform: translate(3%, 0%); + transform: translate(3%, 0%); + } + 25% { + -webkit-transform: translate(1%, 2%); + transform: translate(1%, 2%); + } + 30% { + -webkit-transform: translate(1%, 3%); + transform: translate(1%, 3%); + } + 35% { + -webkit-transform: translate(0%, 1%); + transform: translate(0%, 1%); + } + 40% { + -webkit-transform: translate(1%, 1%); + transform: translate(1%, 1%); + } + 45% { + -webkit-transform: translate(1%, 0%); + transform: translate(1%, 0%); + } + 50% { + -webkit-transform: translate(2%, 1%); + transform: translate(2%, 1%); + } + 55% { + -webkit-transform: translate(1%, 2%); + transform: translate(1%, 2%); + } + 60% { + -webkit-transform: translate(3%, 1%); + transform: translate(3%, 1%); + } + 65% { + -webkit-transform: translate(0%, 2%); + transform: translate(0%, 2%); + } + 70% { + -webkit-transform: translate(3%, 0%); + transform: translate(3%, 0%); + } + 75% { + -webkit-transform: translate(0%, 0%); + transform: translate(0%, 0%); + } + 80% { + -webkit-transform: translate(2%, 3%); + transform: translate(2%, 3%); + } + 85% { + -webkit-transform: translate(1%, 0%); + transform: translate(1%, 0%); + } + 90% { + -webkit-transform: translate(0%, 2%); + transform: translate(0%, 2%); + } + 95% { + -webkit-transform: translate(3%, 2%); + transform: translate(3%, 2%); + } +} +@-webkit-keyframes ld-tremble { + 0% { + -webkit-transform: translate(1%, 1%); + transform: translate(1%, 1%); + } + 5% { + -webkit-transform: translate(0%, 1%); + transform: translate(0%, 1%); + } + 10% { + -webkit-transform: translate(1%, 2%); + transform: translate(1%, 2%); + } + 15% { + -webkit-transform: translate(2%, 1%); + transform: translate(2%, 1%); + } + 20% { + -webkit-transform: translate(3%, 0%); + transform: translate(3%, 0%); + } + 25% { + -webkit-transform: translate(1%, 2%); + transform: translate(1%, 2%); + } + 30% { + -webkit-transform: translate(1%, 3%); + transform: translate(1%, 3%); + } + 35% { + -webkit-transform: translate(0%, 1%); + transform: translate(0%, 1%); + } + 40% { + -webkit-transform: translate(1%, 1%); + transform: translate(1%, 1%); + } + 45% { + -webkit-transform: translate(1%, 0%); + transform: translate(1%, 0%); + } + 50% { + -webkit-transform: translate(2%, 1%); + transform: translate(2%, 1%); + } + 55% { + -webkit-transform: translate(1%, 2%); + transform: translate(1%, 2%); + } + 60% { + -webkit-transform: translate(3%, 1%); + transform: translate(3%, 1%); + } + 65% { + -webkit-transform: translate(0%, 2%); + transform: translate(0%, 2%); + } + 70% { + -webkit-transform: translate(3%, 0%); + transform: translate(3%, 0%); + } + 75% { + -webkit-transform: translate(0%, 0%); + transform: translate(0%, 0%); + } + 80% { + -webkit-transform: translate(2%, 3%); + transform: translate(2%, 3%); + } + 85% { + -webkit-transform: translate(1%, 0%); + transform: translate(1%, 0%); + } + 90% { + -webkit-transform: translate(0%, 2%); + transform: translate(0%, 2%); + } + 95% { + -webkit-transform: translate(3%, 2%); + transform: translate(3%, 2%); + } +} +.ld.ld-tremble { + -webkit-animation: ld-tremble 1s infinite; + animation: ld-tremble 1s infinite; +} +@keyframes ld-wander-h { + 0% { + -webkit-transform: translate(-35%, 0); + transform: translate(-35%, 0); + } + 50% { + -webkit-transform: translate(35%, 0); + transform: translate(35%, 0); + } + 100% { + -webkit-transform: translate(-35%, 0); + transform: translate(-35%, 0); + } +} +@-webkit-keyframes ld-wander-h { + 0% { + -webkit-transform: translate(-35%, 0); + transform: translate(-35%, 0); + } + 50% { + -webkit-transform: translate(35%, 0); + transform: translate(35%, 0); + } + 100% { + -webkit-transform: translate(-35%, 0); + transform: translate(-35%, 0); + } +} +.ld.ld-wander-h { + -webkit-animation: ld-wander-h 1s infinite ease-out; + animation: ld-wander-h 1s infinite ease-out; +} +@keyframes ld-wander-v { + 0% { + -webkit-transform: translate(0, -35%); + transform: translate(0, -35%); + } + 50% { + -webkit-transform: translate(0, 35%); + transform: translate(0, 35%); + } + 100% { + -webkit-transform: translate(0, -35%); + transform: translate(0, -35%); + } +} +@-webkit-keyframes ld-wander-v { + 0% { + -webkit-transform: translate(0, -35%); + transform: translate(0, -35%); + } + 50% { + -webkit-transform: translate(0, 35%); + transform: translate(0, 35%); + } + 100% { + -webkit-transform: translate(0, -35%); + transform: translate(0, -35%); + } +} +.ld.ld-wander-v { + -webkit-animation: ld-wander-v 1s infinite ease-out; + animation: ld-wander-v 1s infinite ease-out; +} +@keyframes ld-jingle { + 0% { + -webkit-transform: translate(0, -40%) rotate(0deg) translate(0, 40%); + transform: translate(0, -40%) rotate(0deg) translate(0, 40%); + } + 4% { + -webkit-transform: translate(0, -40%) rotate(11deg) translate(0, 40%); + transform: translate(0, -40%) rotate(11deg) translate(0, 40%); + } + 10% { + -webkit-transform: translate(0, -40%) rotate(15deg) translate(0, 40%); + transform: translate(0, -40%) rotate(15deg) translate(0, 40%); + } + 18% { + -webkit-transform: translate(0, -40%) rotate(-11deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-11deg) translate(0, 40%); + } + 20% { + -webkit-transform: translate(0, -40%) rotate(-13deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-13deg) translate(0, 40%); + } + 21% { + -webkit-transform: translate(0, -40%) rotate(-12deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-12deg) translate(0, 40%); + } + 22% { + -webkit-transform: translate(0, -40%) rotate(-10deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-10deg) translate(0, 40%); + } + 24% { + -webkit-transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + } + 26% { + -webkit-transform: translate(0, -40%) rotate(3deg) translate(0, 40%); + transform: translate(0, -40%) rotate(3deg) translate(0, 40%); + } + 28% { + -webkit-transform: translate(0, -40%) rotate(9deg) translate(0, 40%); + transform: translate(0, -40%) rotate(9deg) translate(0, 40%); + } + 30% { + -webkit-transform: translate(0, -40%) rotate(10deg) translate(0, 40%); + transform: translate(0, -40%) rotate(10deg) translate(0, 40%); + } + 31% { + -webkit-transform: translate(0, -40%) rotate(9deg) translate(0, 40%); + transform: translate(0, -40%) rotate(9deg) translate(0, 40%); + } + 33% { + -webkit-transform: translate(0, -40%) rotate(5deg) translate(0, 40%); + transform: translate(0, -40%) rotate(5deg) translate(0, 40%); + } + 34% { + -webkit-transform: translate(0, -40%) rotate(1deg) translate(0, 40%); + transform: translate(0, -40%) rotate(1deg) translate(0, 40%); + } + 36% { + -webkit-transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + } + 39% { + -webkit-transform: translate(0, -40%) rotate(-8deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-8deg) translate(0, 40%); + } + 40% { + -webkit-transform: translate(0, -40%) rotate(-7deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-7deg) translate(0, 40%); + } + 44% { + -webkit-transform: translate(0, -40%) rotate(3deg) translate(0, 40%); + transform: translate(0, -40%) rotate(3deg) translate(0, 40%); + } + 47% { + -webkit-transform: translate(0, -40%) rotate(7deg) translate(0, 40%); + transform: translate(0, -40%) rotate(7deg) translate(0, 40%); + } + 56% { + -webkit-transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + } + 63% { + -webkit-transform: translate(0, -40%) rotate(1deg) translate(0, 40%); + transform: translate(0, -40%) rotate(1deg) translate(0, 40%); + } + 75% { + -webkit-transform: translate(0, -40%) rotate(-1deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-1deg) translate(0, 40%); + } + 100% { + -webkit-transform: translate(0, -40%) rotate(0deg) translate(0, 40%); + transform: translate(0, -40%) rotate(0deg) translate(0, 40%); + } +} +@-webkit-keyframes ld-jingle { + 0% { + -webkit-transform: translate(0, -40%) rotate(0deg) translate(0, 40%); + transform: translate(0, -40%) rotate(0deg) translate(0, 40%); + } + 4% { + -webkit-transform: translate(0, -40%) rotate(11deg) translate(0, 40%); + transform: translate(0, -40%) rotate(11deg) translate(0, 40%); + } + 10% { + -webkit-transform: translate(0, -40%) rotate(15deg) translate(0, 40%); + transform: translate(0, -40%) rotate(15deg) translate(0, 40%); + } + 18% { + -webkit-transform: translate(0, -40%) rotate(-11deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-11deg) translate(0, 40%); + } + 20% { + -webkit-transform: translate(0, -40%) rotate(-13deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-13deg) translate(0, 40%); + } + 21% { + -webkit-transform: translate(0, -40%) rotate(-12deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-12deg) translate(0, 40%); + } + 22% { + -webkit-transform: translate(0, -40%) rotate(-10deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-10deg) translate(0, 40%); + } + 24% { + -webkit-transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + } + 26% { + -webkit-transform: translate(0, -40%) rotate(3deg) translate(0, 40%); + transform: translate(0, -40%) rotate(3deg) translate(0, 40%); + } + 28% { + -webkit-transform: translate(0, -40%) rotate(9deg) translate(0, 40%); + transform: translate(0, -40%) rotate(9deg) translate(0, 40%); + } + 30% { + -webkit-transform: translate(0, -40%) rotate(10deg) translate(0, 40%); + transform: translate(0, -40%) rotate(10deg) translate(0, 40%); + } + 31% { + -webkit-transform: translate(0, -40%) rotate(9deg) translate(0, 40%); + transform: translate(0, -40%) rotate(9deg) translate(0, 40%); + } + 33% { + -webkit-transform: translate(0, -40%) rotate(5deg) translate(0, 40%); + transform: translate(0, -40%) rotate(5deg) translate(0, 40%); + } + 34% { + -webkit-transform: translate(0, -40%) rotate(1deg) translate(0, 40%); + transform: translate(0, -40%) rotate(1deg) translate(0, 40%); + } + 36% { + -webkit-transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + } + 39% { + -webkit-transform: translate(0, -40%) rotate(-8deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-8deg) translate(0, 40%); + } + 40% { + -webkit-transform: translate(0, -40%) rotate(-7deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-7deg) translate(0, 40%); + } + 44% { + -webkit-transform: translate(0, -40%) rotate(3deg) translate(0, 40%); + transform: translate(0, -40%) rotate(3deg) translate(0, 40%); + } + 47% { + -webkit-transform: translate(0, -40%) rotate(7deg) translate(0, 40%); + transform: translate(0, -40%) rotate(7deg) translate(0, 40%); + } + 56% { + -webkit-transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-5deg) translate(0, 40%); + } + 63% { + -webkit-transform: translate(0, -40%) rotate(1deg) translate(0, 40%); + transform: translate(0, -40%) rotate(1deg) translate(0, 40%); + } + 75% { + -webkit-transform: translate(0, -40%) rotate(-1deg) translate(0, 40%); + transform: translate(0, -40%) rotate(-1deg) translate(0, 40%); + } + 100% { + -webkit-transform: translate(0, -40%) rotate(0deg) translate(0, 40%); + transform: translate(0, -40%) rotate(0deg) translate(0, 40%); + } +} +.ld.ld-jingle { + -webkit-animation: ld-jingle 1s infinite; + animation: ld-jingle 1s infinite; +} +@keyframes ld-swim { + 0% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } + 12.5% { + -webkit-transform: translate(5%, -10%) rotate(3deg); + transform: translate(5%, -10%) rotate(3deg); + } + 25% { + -webkit-transform: translate(0, -15%) rotate(6deg); + transform: translate(0, -15%) rotate(6deg); + } + 37.5% { + -webkit-transform: translate(-5%, -10%) rotate(3deg); + transform: translate(-5%, -10%) rotate(3deg); + } + 50% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } + 62.5% { + -webkit-transform: translate(5%, 10%) rotate(-3deg); + transform: translate(5%, 10%) rotate(-3deg); + } + 75% { + -webkit-transform: translate(0, 15%) rotate(-6deg); + transform: translate(0, 15%) rotate(-6deg); + } + 87.5% { + -webkit-transform: translate(-5%, 10%) rotate(-3deg); + transform: translate(-5%, 10%) rotate(-3deg); + } + 100% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } +} +@-webkit-keyframes ld-swim { + 0% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } + 12.5% { + -webkit-transform: translate(5%, -10%) rotate(3deg); + transform: translate(5%, -10%) rotate(3deg); + } + 25% { + -webkit-transform: translate(0, -15%) rotate(6deg); + transform: translate(0, -15%) rotate(6deg); + } + 37.5% { + -webkit-transform: translate(-5%, -10%) rotate(3deg); + transform: translate(-5%, -10%) rotate(3deg); + } + 50% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } + 62.5% { + -webkit-transform: translate(5%, 10%) rotate(-3deg); + transform: translate(5%, 10%) rotate(-3deg); + } + 75% { + -webkit-transform: translate(0, 15%) rotate(-6deg); + transform: translate(0, 15%) rotate(-6deg); + } + 87.5% { + -webkit-transform: translate(-5%, 10%) rotate(-3deg); + transform: translate(-5%, 10%) rotate(-3deg); + } + 100% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } +} +.ld.ld-swim { + -webkit-animation: ld-swim 3s infinite linear; + animation: ld-swim 3s infinite linear; +} +@keyframes ld-leaf { + 0% { + -webkit-transform: translate(-14.7%, -117%) rotate(-0.3deg); + transform: translate(-14.7%, -117%) rotate(-0.3deg); + } + 1% { + -webkit-transform: translate(-14.399999999999999%, -112.5%) rotate(-0.6deg); + transform: translate(-14.399999999999999%, -112.5%) rotate(-0.6deg); + } + 2% { + -webkit-transform: translate(-13.8%, -102.00000000000001%) rotate(-1.2deg); + transform: translate(-13.8%, -102.00000000000001%) rotate(-1.2deg); + } + 3% { + -webkit-transform: translate(-13.5%, -100.5%) rotate(-1.5deg); + transform: translate(-13.5%, -100.5%) rotate(-1.5deg); + } + 5% { + -webkit-transform: translate(-7.199999999999999%, -87%) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999%, -87%) rotate(-7.800000000000001deg); + } + 7% { + -webkit-transform: translate(5.399999999999999%, -79.5%) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999%, -79.5%) rotate(-20.400000000000002deg); + } + 10% { + -webkit-transform: translate(12.9%, -76.5%) rotate(-27.900000000000002deg); + transform: translate(12.9%, -76.5%) rotate(-27.900000000000002deg); + } + 12% { + -webkit-transform: translate(14.399999999999999%, -75%) rotate(-29.4deg); + transform: translate(14.399999999999999%, -75%) rotate(-29.4deg); + } + 13% { + -webkit-transform: translate(14.7%, -75%) rotate(-29.7deg); + transform: translate(14.7%, -75%) rotate(-29.7deg); + } + 14% { + -webkit-transform: translate(15%, -75%) rotate(-30deg); + transform: translate(15%, -75%) rotate(-30deg); + } + 15% { + -webkit-transform: translate(14.399999999999999%, -69%) rotate(0.6deg); + transform: translate(14.399999999999999%, -69%) rotate(0.6deg); + } + 16% { + -webkit-transform: translate(13.8%, -58.5%) rotate(1.2deg); + transform: translate(13.8%, -58.5%) rotate(1.2deg); + } + 19% { + -webkit-transform: translate(7.199999999999999%, -45%) rotate(7.800000000000001deg); + transform: translate(7.199999999999999%, -45%) rotate(7.800000000000001deg); + } + 21% { + -webkit-transform: translate(-5.399999999999999%, -37.5%) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999%, -37.5%) rotate(20.400000000000002deg); + } + 24% { + -webkit-transform: translate(-12.9%, -33%) rotate(27.900000000000002deg); + transform: translate(-12.9%, -33%) rotate(27.900000000000002deg); + } + 26% { + -webkit-transform: translate(-14.399999999999999%, -33%) rotate(29.4deg); + transform: translate(-14.399999999999999%, -33%) rotate(29.4deg); + } + 27% { + -webkit-transform: translate(-14.7%, -31.5%) rotate(29.7deg); + transform: translate(-14.7%, -31.5%) rotate(29.7deg); + } + 28% { + -webkit-transform: translate(-15%, -31.5%) rotate(30deg); + transform: translate(-15%, -31.5%) rotate(30deg); + } + 29% { + -webkit-transform: translate(-14.399999999999999%, -27%) rotate(-0.6deg); + transform: translate(-14.399999999999999%, -27%) rotate(-0.6deg); + } + 30% { + -webkit-transform: translate(-13.8%, -16.5%) rotate(-1.2deg); + transform: translate(-13.8%, -16.5%) rotate(-1.2deg); + } + 31% { + -webkit-transform: translate(-13.5%, -15%) rotate(-1.5deg); + transform: translate(-13.5%, -15%) rotate(-1.5deg); + } + 33% { + -webkit-transform: translate(-7.199999999999999%, -1.5%) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999%, -1.5%) rotate(-7.800000000000001deg); + } + 36% { + -webkit-transform: translate(5.399999999999999%, 4.5%) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999%, 4.5%) rotate(-20.400000000000002deg); + } + 38% { + -webkit-transform: translate(12.9%, 9%) rotate(-27.900000000000002deg); + transform: translate(12.9%, 9%) rotate(-27.900000000000002deg); + } + 40% { + -webkit-transform: translate(14.399999999999999%, 10.500000000000002%) rotate(-29.4deg); + transform: translate(14.399999999999999%, 10.500000000000002%) rotate(-29.4deg); + } + 41% { + -webkit-transform: translate(14.7%, 10.500000000000002%) rotate(-29.7deg); + transform: translate(14.7%, 10.500000000000002%) rotate(-29.7deg); + } + 42% { + -webkit-transform: translate(15%, 10.500000000000002%) rotate(-30deg); + transform: translate(15%, 10.500000000000002%) rotate(-30deg); + } + 43% { + -webkit-transform: translate(15%, 10.500000000000002%) rotate(-30deg); + transform: translate(15%, 10.500000000000002%) rotate(-30deg); + } + 43% { + -webkit-transform: translate(14.7%, 10.500000000000002%) rotate(0.3deg); + transform: translate(14.7%, 10.500000000000002%) rotate(0.3deg); + } + 43% { + -webkit-transform: translate(14.399999999999999%, 16.5%) rotate(0.6deg); + transform: translate(14.399999999999999%, 16.5%) rotate(0.6deg); + } + 45% { + -webkit-transform: translate(13.8%, 25.500000000000004%) rotate(1.2deg); + transform: translate(13.8%, 25.500000000000004%) rotate(1.2deg); + } + 45% { + -webkit-transform: translate(13.5%, 27%) rotate(1.5deg); + transform: translate(13.5%, 27%) rotate(1.5deg); + } + 48% { + -webkit-transform: translate(7.199999999999999%, 40.5%) rotate(7.800000000000001deg); + transform: translate(7.199999999999999%, 40.5%) rotate(7.800000000000001deg); + } + 50% { + -webkit-transform: translate(-5.399999999999999%, 48%) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999%, 48%) rotate(20.400000000000002deg); + } + 52% { + -webkit-transform: translate(-12.9%, 51.00000000000001%) rotate(27.900000000000002deg); + transform: translate(-12.9%, 51.00000000000001%) rotate(27.900000000000002deg); + } + 54% { + -webkit-transform: translate(-14.399999999999999%, 52.5%) rotate(29.4deg); + transform: translate(-14.399999999999999%, 52.5%) rotate(29.4deg); + } + 56% { + -webkit-transform: translate(-14.7%, 54%) rotate(29.7deg); + transform: translate(-14.7%, 54%) rotate(29.7deg); + } + 57% { + -webkit-transform: translate(-14.7%, 54%) rotate(-0.3deg); + transform: translate(-14.7%, 54%) rotate(-0.3deg); + } + 58% { + -webkit-transform: translate(-14.399999999999999%, 58.5%) rotate(-0.6deg); + transform: translate(-14.399999999999999%, 58.5%) rotate(-0.6deg); + } + 59% { + -webkit-transform: translate(-13.5%, 70.5%) rotate(-1.5deg); + transform: translate(-13.5%, 70.5%) rotate(-1.5deg); + } + 62% { + -webkit-transform: translate(-7.199999999999999%, 84.00000000000001%) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999%, 84.00000000000001%) rotate(-7.800000000000001deg); + } + 64% { + -webkit-transform: translate(5.399999999999999%, 91.5%) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999%, 91.5%) rotate(-20.400000000000002deg); + } + 67% { + -webkit-transform: translate(12.9%, 94.5%) rotate(-27.900000000000002deg); + transform: translate(12.9%, 94.5%) rotate(-27.900000000000002deg); + } + 69% { + -webkit-transform: translate(14.399999999999999%, 96%) rotate(-29.4deg); + transform: translate(14.399999999999999%, 96%) rotate(-29.4deg); + } + 70% { + -webkit-transform: translate(14.7%, 96%) rotate(-29.7deg); + transform: translate(14.7%, 96%) rotate(-29.7deg); + } + 71% { + -webkit-transform: translate(15%, 96%) rotate(-30deg); + transform: translate(15%, 96%) rotate(-30deg); + } + 72% { + -webkit-transform: translate(14.399999999999999%, 102.00000000000001%) rotate(0.6deg); + transform: translate(14.399999999999999%, 102.00000000000001%) rotate(0.6deg); + } + 73% { + -webkit-transform: translate(13.8%, 111%) rotate(1.2deg); + transform: translate(13.8%, 111%) rotate(1.2deg); + } + 74% { + -webkit-transform: translate(13.5%, 112.5%) rotate(1.5deg); + transform: translate(13.5%, 112.5%) rotate(1.5deg); + } + 76% { + -webkit-transform: translate(7.199999999999999%, 126%) rotate(7.800000000000001deg); + transform: translate(7.199999999999999%, 126%) rotate(7.800000000000001deg); + } + 79% { + -webkit-transform: translate(-5.399999999999999%, 133.5%) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999%, 133.5%) rotate(20.400000000000002deg); + } + 81% { + -webkit-transform: translate(-12.9%, 138%) rotate(27.900000000000002deg); + transform: translate(-12.9%, 138%) rotate(27.900000000000002deg); + } + 83% { + -webkit-transform: translate(-14.399999999999999%, 139.5%) rotate(29.4deg); + transform: translate(-14.399999999999999%, 139.5%) rotate(29.4deg); + } + 84% { + -webkit-transform: translate(-14.7%, 139.5%) rotate(29.7deg); + transform: translate(-14.7%, 139.5%) rotate(29.7deg); + } + 85% { + -webkit-transform: translate(-15%, 139.5%) rotate(30deg); + transform: translate(-15%, 139.5%) rotate(30deg); + } + 86% { + -webkit-transform: translate(-14.7%, 139.5%) rotate(-0.3deg); + transform: translate(-14.7%, 139.5%) rotate(-0.3deg); + } + 86% { + -webkit-transform: translate(-14.399999999999999%, 144%) rotate(-0.6deg); + transform: translate(-14.399999999999999%, 144%) rotate(-0.6deg); + } + 88% { + -webkit-transform: translate(-13.5%, 156%) rotate(-1.5deg); + transform: translate(-13.5%, 156%) rotate(-1.5deg); + } + 90% { + -webkit-transform: translate(-7.199999999999999%, 169.49999999999997%) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999%, 169.49999999999997%) rotate(-7.800000000000001deg); + } + 93% { + -webkit-transform: translate(5.399999999999999%, 177%) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999%, 177%) rotate(-20.400000000000002deg); + } + 95% { + -webkit-transform: translate(12.9%, 180%) rotate(-27.900000000000002deg); + transform: translate(12.9%, 180%) rotate(-27.900000000000002deg); + } + 97% { + -webkit-transform: translate(14.399999999999999%, 181.5%) rotate(-29.4deg); + transform: translate(14.399999999999999%, 181.5%) rotate(-29.4deg); + } + 99% { + -webkit-transform: translate(14.7%, 181.5%) rotate(-29.7deg); + transform: translate(14.7%, 181.5%) rotate(-29.7deg); + } + 100% { + -webkit-transform: translate(15%, 181.5%) rotate(-30deg); + transform: translate(15%, 181.5%) rotate(-30deg); + } +} +@-webkit-keyframes ld-leaf { + 0% { + -webkit-transform: translate(-14.7%, -117%) rotate(-0.3deg); + transform: translate(-14.7%, -117%) rotate(-0.3deg); + } + 1% { + -webkit-transform: translate(-14.399999999999999%, -112.5%) rotate(-0.6deg); + transform: translate(-14.399999999999999%, -112.5%) rotate(-0.6deg); + } + 2% { + -webkit-transform: translate(-13.8%, -102.00000000000001%) rotate(-1.2deg); + transform: translate(-13.8%, -102.00000000000001%) rotate(-1.2deg); + } + 3% { + -webkit-transform: translate(-13.5%, -100.5%) rotate(-1.5deg); + transform: translate(-13.5%, -100.5%) rotate(-1.5deg); + } + 5% { + -webkit-transform: translate(-7.199999999999999%, -87%) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999%, -87%) rotate(-7.800000000000001deg); + } + 7% { + -webkit-transform: translate(5.399999999999999%, -79.5%) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999%, -79.5%) rotate(-20.400000000000002deg); + } + 10% { + -webkit-transform: translate(12.9%, -76.5%) rotate(-27.900000000000002deg); + transform: translate(12.9%, -76.5%) rotate(-27.900000000000002deg); + } + 12% { + -webkit-transform: translate(14.399999999999999%, -75%) rotate(-29.4deg); + transform: translate(14.399999999999999%, -75%) rotate(-29.4deg); + } + 13% { + -webkit-transform: translate(14.7%, -75%) rotate(-29.7deg); + transform: translate(14.7%, -75%) rotate(-29.7deg); + } + 14% { + -webkit-transform: translate(15%, -75%) rotate(-30deg); + transform: translate(15%, -75%) rotate(-30deg); + } + 15% { + -webkit-transform: translate(14.399999999999999%, -69%) rotate(0.6deg); + transform: translate(14.399999999999999%, -69%) rotate(0.6deg); + } + 16% { + -webkit-transform: translate(13.8%, -58.5%) rotate(1.2deg); + transform: translate(13.8%, -58.5%) rotate(1.2deg); + } + 19% { + -webkit-transform: translate(7.199999999999999%, -45%) rotate(7.800000000000001deg); + transform: translate(7.199999999999999%, -45%) rotate(7.800000000000001deg); + } + 21% { + -webkit-transform: translate(-5.399999999999999%, -37.5%) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999%, -37.5%) rotate(20.400000000000002deg); + } + 24% { + -webkit-transform: translate(-12.9%, -33%) rotate(27.900000000000002deg); + transform: translate(-12.9%, -33%) rotate(27.900000000000002deg); + } + 26% { + -webkit-transform: translate(-14.399999999999999%, -33%) rotate(29.4deg); + transform: translate(-14.399999999999999%, -33%) rotate(29.4deg); + } + 27% { + -webkit-transform: translate(-14.7%, -31.5%) rotate(29.7deg); + transform: translate(-14.7%, -31.5%) rotate(29.7deg); + } + 28% { + -webkit-transform: translate(-15%, -31.5%) rotate(30deg); + transform: translate(-15%, -31.5%) rotate(30deg); + } + 29% { + -webkit-transform: translate(-14.399999999999999%, -27%) rotate(-0.6deg); + transform: translate(-14.399999999999999%, -27%) rotate(-0.6deg); + } + 30% { + -webkit-transform: translate(-13.8%, -16.5%) rotate(-1.2deg); + transform: translate(-13.8%, -16.5%) rotate(-1.2deg); + } + 31% { + -webkit-transform: translate(-13.5%, -15%) rotate(-1.5deg); + transform: translate(-13.5%, -15%) rotate(-1.5deg); + } + 33% { + -webkit-transform: translate(-7.199999999999999%, -1.5%) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999%, -1.5%) rotate(-7.800000000000001deg); + } + 36% { + -webkit-transform: translate(5.399999999999999%, 4.5%) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999%, 4.5%) rotate(-20.400000000000002deg); + } + 38% { + -webkit-transform: translate(12.9%, 9%) rotate(-27.900000000000002deg); + transform: translate(12.9%, 9%) rotate(-27.900000000000002deg); + } + 40% { + -webkit-transform: translate(14.399999999999999%, 10.500000000000002%) rotate(-29.4deg); + transform: translate(14.399999999999999%, 10.500000000000002%) rotate(-29.4deg); + } + 41% { + -webkit-transform: translate(14.7%, 10.500000000000002%) rotate(-29.7deg); + transform: translate(14.7%, 10.500000000000002%) rotate(-29.7deg); + } + 42% { + -webkit-transform: translate(15%, 10.500000000000002%) rotate(-30deg); + transform: translate(15%, 10.500000000000002%) rotate(-30deg); + } + 43% { + -webkit-transform: translate(15%, 10.500000000000002%) rotate(-30deg); + transform: translate(15%, 10.500000000000002%) rotate(-30deg); + } + 43% { + -webkit-transform: translate(14.7%, 10.500000000000002%) rotate(0.3deg); + transform: translate(14.7%, 10.500000000000002%) rotate(0.3deg); + } + 43% { + -webkit-transform: translate(14.399999999999999%, 16.5%) rotate(0.6deg); + transform: translate(14.399999999999999%, 16.5%) rotate(0.6deg); + } + 45% { + -webkit-transform: translate(13.8%, 25.500000000000004%) rotate(1.2deg); + transform: translate(13.8%, 25.500000000000004%) rotate(1.2deg); + } + 45% { + -webkit-transform: translate(13.5%, 27%) rotate(1.5deg); + transform: translate(13.5%, 27%) rotate(1.5deg); + } + 48% { + -webkit-transform: translate(7.199999999999999%, 40.5%) rotate(7.800000000000001deg); + transform: translate(7.199999999999999%, 40.5%) rotate(7.800000000000001deg); + } + 50% { + -webkit-transform: translate(-5.399999999999999%, 48%) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999%, 48%) rotate(20.400000000000002deg); + } + 52% { + -webkit-transform: translate(-12.9%, 51.00000000000001%) rotate(27.900000000000002deg); + transform: translate(-12.9%, 51.00000000000001%) rotate(27.900000000000002deg); + } + 54% { + -webkit-transform: translate(-14.399999999999999%, 52.5%) rotate(29.4deg); + transform: translate(-14.399999999999999%, 52.5%) rotate(29.4deg); + } + 56% { + -webkit-transform: translate(-14.7%, 54%) rotate(29.7deg); + transform: translate(-14.7%, 54%) rotate(29.7deg); + } + 57% { + -webkit-transform: translate(-14.7%, 54%) rotate(-0.3deg); + transform: translate(-14.7%, 54%) rotate(-0.3deg); + } + 58% { + -webkit-transform: translate(-14.399999999999999%, 58.5%) rotate(-0.6deg); + transform: translate(-14.399999999999999%, 58.5%) rotate(-0.6deg); + } + 59% { + -webkit-transform: translate(-13.5%, 70.5%) rotate(-1.5deg); + transform: translate(-13.5%, 70.5%) rotate(-1.5deg); + } + 62% { + -webkit-transform: translate(-7.199999999999999%, 84.00000000000001%) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999%, 84.00000000000001%) rotate(-7.800000000000001deg); + } + 64% { + -webkit-transform: translate(5.399999999999999%, 91.5%) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999%, 91.5%) rotate(-20.400000000000002deg); + } + 67% { + -webkit-transform: translate(12.9%, 94.5%) rotate(-27.900000000000002deg); + transform: translate(12.9%, 94.5%) rotate(-27.900000000000002deg); + } + 69% { + -webkit-transform: translate(14.399999999999999%, 96%) rotate(-29.4deg); + transform: translate(14.399999999999999%, 96%) rotate(-29.4deg); + } + 70% { + -webkit-transform: translate(14.7%, 96%) rotate(-29.7deg); + transform: translate(14.7%, 96%) rotate(-29.7deg); + } + 71% { + -webkit-transform: translate(15%, 96%) rotate(-30deg); + transform: translate(15%, 96%) rotate(-30deg); + } + 72% { + -webkit-transform: translate(14.399999999999999%, 102.00000000000001%) rotate(0.6deg); + transform: translate(14.399999999999999%, 102.00000000000001%) rotate(0.6deg); + } + 73% { + -webkit-transform: translate(13.8%, 111%) rotate(1.2deg); + transform: translate(13.8%, 111%) rotate(1.2deg); + } + 74% { + -webkit-transform: translate(13.5%, 112.5%) rotate(1.5deg); + transform: translate(13.5%, 112.5%) rotate(1.5deg); + } + 76% { + -webkit-transform: translate(7.199999999999999%, 126%) rotate(7.800000000000001deg); + transform: translate(7.199999999999999%, 126%) rotate(7.800000000000001deg); + } + 79% { + -webkit-transform: translate(-5.399999999999999%, 133.5%) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999%, 133.5%) rotate(20.400000000000002deg); + } + 81% { + -webkit-transform: translate(-12.9%, 138%) rotate(27.900000000000002deg); + transform: translate(-12.9%, 138%) rotate(27.900000000000002deg); + } + 83% { + -webkit-transform: translate(-14.399999999999999%, 139.5%) rotate(29.4deg); + transform: translate(-14.399999999999999%, 139.5%) rotate(29.4deg); + } + 84% { + -webkit-transform: translate(-14.7%, 139.5%) rotate(29.7deg); + transform: translate(-14.7%, 139.5%) rotate(29.7deg); + } + 85% { + -webkit-transform: translate(-15%, 139.5%) rotate(30deg); + transform: translate(-15%, 139.5%) rotate(30deg); + } + 86% { + -webkit-transform: translate(-14.7%, 139.5%) rotate(-0.3deg); + transform: translate(-14.7%, 139.5%) rotate(-0.3deg); + } + 86% { + -webkit-transform: translate(-14.399999999999999%, 144%) rotate(-0.6deg); + transform: translate(-14.399999999999999%, 144%) rotate(-0.6deg); + } + 88% { + -webkit-transform: translate(-13.5%, 156%) rotate(-1.5deg); + transform: translate(-13.5%, 156%) rotate(-1.5deg); + } + 90% { + -webkit-transform: translate(-7.199999999999999%, 169.49999999999997%) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999%, 169.49999999999997%) rotate(-7.800000000000001deg); + } + 93% { + -webkit-transform: translate(5.399999999999999%, 177%) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999%, 177%) rotate(-20.400000000000002deg); + } + 95% { + -webkit-transform: translate(12.9%, 180%) rotate(-27.900000000000002deg); + transform: translate(12.9%, 180%) rotate(-27.900000000000002deg); + } + 97% { + -webkit-transform: translate(14.399999999999999%, 181.5%) rotate(-29.4deg); + transform: translate(14.399999999999999%, 181.5%) rotate(-29.4deg); + } + 99% { + -webkit-transform: translate(14.7%, 181.5%) rotate(-29.7deg); + transform: translate(14.7%, 181.5%) rotate(-29.7deg); + } + 100% { + -webkit-transform: translate(15%, 181.5%) rotate(-30deg); + transform: translate(15%, 181.5%) rotate(-30deg); + } +} +.ld.ld-leaf { + -webkit-animation: ld-leaf 4s infinite cubic-bezier(0.1, 0.5, 0.1, 0.5); + animation: ld-leaf 4s infinite cubic-bezier(0.1, 0.5, 0.1, 0.5); +} +@keyframes ld-slot { + 0% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 9.09% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 9.1% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 16.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 17% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 23.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 23.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 29.59% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 29.6% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 34.49% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 34.5% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 38.49% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 38.5% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 41.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 41.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 44.39% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 44.4% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 46.29% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 46.3% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 47.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 47.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 48.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 48.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.39% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 49.4% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 49.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 50.190000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 50.59% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50.6% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 51.190000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 51.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 52.190000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 52.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 53.690000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 53.7% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 55.59% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 55.6% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 58.190000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 58.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 61.49% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 61.5% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 65.49% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 65.5% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 70.39% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 70.4% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 76.19% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 76.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 82.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 83% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 90.89% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 90.9% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 99.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 100% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } +} +@-webkit-keyframes ld-slot { + 0% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 9.09% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 9.1% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 16.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 17% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 23.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 23.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 29.59% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 29.6% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 34.49% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 34.5% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 38.49% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 38.5% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 41.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 41.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 44.39% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 44.4% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 46.29% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 46.3% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 47.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 47.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 48.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 48.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.39% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 49.4% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.79% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 49.8% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 49.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 50.190000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 50.59% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 50.6% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 51.190000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 51.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 52.190000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 52.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 53.690000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 53.7% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 55.59% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 55.6% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 58.190000000000005% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 58.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 61.49% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 61.5% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 65.49% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 65.5% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 70.39% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 70.4% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 76.19% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 76.2% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 82.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 83% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 90.89% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 90.9% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } + 99.99% { + -webkit-transform: translate(0, 160%); + transform: translate(0, 160%); + } + 100% { + -webkit-transform: translate(0, -160%); + transform: translate(0, -160%); + } +} +.ld.ld-slot { + -webkit-animation: ld-slot 6s infinite linear; + animation: ld-slot 6s infinite linear; +} +@keyframes ld-bounce-px { + 0%, 90% { + animation-timing-function: linear; + } + 10% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 50% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 0% { + -webkit-transform: translate(0, 30px) scaleY(0.5); + transform: translate(0, 30px) scaleY(0.5); + } + 10% { + -webkit-transform: translate(0, 5px) scaleY(1.1); + transform: translate(0, 5px) scaleY(1.1); + } + 50% { + -webkit-transform: translate(0, -37px) scaleY(1.1); + transform: translate(0, -37px) scaleY(1.1); + } + 90% { + -webkit-transform: translate(0, 5px) scaleY(1.1); + transform: translate(0, 5px) scaleY(1.1); + } + 100% { + -webkit-transform: translate(0, 30px) scaleY(0.5); + transform: translate(0, 30px) scaleY(0.5); + } +} +@-webkit-keyframes ld-bounce-px { + 0%, 90% { + animation-timing-function: linear; + } + 10% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 50% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 0% { + -webkit-transform: translate(0, 30px) scaleY(0.5); + transform: translate(0, 30px) scaleY(0.5); + } + 10% { + -webkit-transform: translate(0, 5px) scaleY(1.1); + transform: translate(0, 5px) scaleY(1.1); + } + 50% { + -webkit-transform: translate(0, -37px) scaleY(1.1); + transform: translate(0, -37px) scaleY(1.1); + } + 90% { + -webkit-transform: translate(0, 5px) scaleY(1.1); + transform: translate(0, 5px) scaleY(1.1); + } + 100% { + -webkit-transform: translate(0, 30px) scaleY(0.5); + transform: translate(0, 30px) scaleY(0.5); + } +} +.ld.ld-bounce-px { + -webkit-animation: ld-bounce-px 1s infinite; + animation: ld-bounce-px 1s infinite; +} +@keyframes ld-bounce-px-rtl { + 0% { + -webkit-transform: translate(80px, -20px); + transform: translate(80px, -20px); + } + 12.5% { + -webkit-transform: translate(60px, -12px); + transform: translate(60px, -12px); + } + 25% { + -webkit-transform: translate(40px, 0); + transform: translate(40px, 0); + } + 37.5% { + -webkit-transform: translate(25px, -12px); + transform: translate(25px, -12px); + } + 50% { + -webkit-transform: translate(0, -20px); + transform: translate(0, -20px); + } + 62.5% { + -webkit-transform: translate(-25px, -12px); + transform: translate(-25px, -12px); + } + 75% { + -webkit-transform: translate(-40px, 0); + transform: translate(-40px, 0); + } + 87.5% { + -webkit-transform: translate(-60px, -12px); + transform: translate(-60px, -12px); + } + 100% { + -webkit-transform: translate(-80px, -20px); + transform: translate(-80px, -20px); + } +} +@-webkit-keyframes ld-bounce-px-rtl { + 0% { + -webkit-transform: translate(80px, -20px); + transform: translate(80px, -20px); + } + 12.5% { + -webkit-transform: translate(60px, -12px); + transform: translate(60px, -12px); + } + 25% { + -webkit-transform: translate(40px, 0); + transform: translate(40px, 0); + } + 37.5% { + -webkit-transform: translate(25px, -12px); + transform: translate(25px, -12px); + } + 50% { + -webkit-transform: translate(0, -20px); + transform: translate(0, -20px); + } + 62.5% { + -webkit-transform: translate(-25px, -12px); + transform: translate(-25px, -12px); + } + 75% { + -webkit-transform: translate(-40px, 0); + transform: translate(-40px, 0); + } + 87.5% { + -webkit-transform: translate(-60px, -12px); + transform: translate(-60px, -12px); + } + 100% { + -webkit-transform: translate(-80px, -20px); + transform: translate(-80px, -20px); + } +} +.ld.ld-bounce-px-rtl { + -webkit-animation: ld-bounce-px-rtl 1s infinite linear; + animation: ld-bounce-px-rtl 1s infinite linear; +} +@keyframes ld-bounce-px-ltr { + 0% { + -webkit-transform: translate(-80px, -20px); + transform: translate(-80px, -20px); + } + 12.5% { + -webkit-transform: translate(-60px, -12px); + transform: translate(-60px, -12px); + } + 25% { + -webkit-transform: translate(-50px, 0); + transform: translate(-50px, 0); + } + 37.5% { + -webkit-transform: translate(-25px, -12px); + transform: translate(-25px, -12px); + } + 50% { + -webkit-transform: translate(0, -20px); + transform: translate(0, -20px); + } + 62.5% { + -webkit-transform: translate(25px, -12px); + transform: translate(25px, -12px); + } + 75% { + -webkit-transform: translate(50px, 0); + transform: translate(50px, 0); + } + 87.5% { + -webkit-transform: translate(60px, -12px); + transform: translate(60px, -12px); + } + 100% { + -webkit-transform: translate(80px, -20px); + transform: translate(80px, -20px); + } +} +@-webkit-keyframes ld-bounce-px-ltr { + 0% { + -webkit-transform: translate(-80px, -20px); + transform: translate(-80px, -20px); + } + 12.5% { + -webkit-transform: translate(-60px, -12px); + transform: translate(-60px, -12px); + } + 25% { + -webkit-transform: translate(-50px, 0); + transform: translate(-50px, 0); + } + 37.5% { + -webkit-transform: translate(-25px, -12px); + transform: translate(-25px, -12px); + } + 50% { + -webkit-transform: translate(0, -20px); + transform: translate(0, -20px); + } + 62.5% { + -webkit-transform: translate(25px, -12px); + transform: translate(25px, -12px); + } + 75% { + -webkit-transform: translate(50px, 0); + transform: translate(50px, 0); + } + 87.5% { + -webkit-transform: translate(60px, -12px); + transform: translate(60px, -12px); + } + 100% { + -webkit-transform: translate(80px, -20px); + transform: translate(80px, -20px); + } +} +.ld.ld-bounce-px-ltr { + -webkit-animation: ld-bounce-px-ltr 1s infinite linear; + animation: ld-bounce-px-ltr 1s infinite linear; +} +@keyframes ld-bounce-a-px { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 12.5%, 37.5%, 62.5%, 87.5% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 12.5% { + -webkit-transform: translate(5px, -28px); + transform: translate(5px, -28px); + } + 25% { + -webkit-transform: translate(10px, 0); + transform: translate(10px, 0); + } + 37.5% { + -webkit-transform: translate(5px, -28px); + transform: translate(5px, -28px); + } + 50% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 62.5% { + -webkit-transform: translate(-5px, -28px); + transform: translate(-5px, -28px); + } + 75% { + -webkit-transform: translate(-10px, 0); + transform: translate(-10px, 0); + } + 87.5% { + -webkit-transform: translate(-5px, -28px); + transform: translate(-5px, -28px); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-bounce-a-px { + 0%, 25%, 50%, 75%, 100% { + animation-timing-function: cubic-bezier(0, 0.4, 0.6, 1); + } + 12.5%, 37.5%, 62.5%, 87.5% { + animation-timing-function: cubic-bezier(0.4, 0, 1, 0.6); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 12.5% { + -webkit-transform: translate(5px, -28px); + transform: translate(5px, -28px); + } + 25% { + -webkit-transform: translate(10px, 0); + transform: translate(10px, 0); + } + 37.5% { + -webkit-transform: translate(5px, -28px); + transform: translate(5px, -28px); + } + 50% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 62.5% { + -webkit-transform: translate(-5px, -28px); + transform: translate(-5px, -28px); + } + 75% { + -webkit-transform: translate(-10px, 0); + transform: translate(-10px, 0); + } + 87.5% { + -webkit-transform: translate(-5px, -28px); + transform: translate(-5px, -28px); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-bounce-a-px { + -webkit-animation: ld-bounce-a-px 2s infinite; + animation: ld-bounce-a-px 2s infinite; +} +@keyframes ld-float-px { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: linear; + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + box-shadow: 0 0 0 rgba(0,0,0,0.3); + } + 30% { + -webkit-transform: translate(0, -10px); + transform: translate(0, -10px); + box-shadow: 0 5px 5px rgba(0,0,0,0.3); + } + 50% { + -webkit-transform: translate(0, -10px); + transform: translate(0, -10px); + box-shadow: 0 5px 5px rgba(0,0,0,0.3); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + box-shadow: 0 0 0 rgba(0,0,0,0.3); + } +} +@-webkit-keyframes ld-float-px { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: linear; + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + box-shadow: 0 0 0 rgba(0,0,0,0.3); + } + 30% { + -webkit-transform: translate(0, -10px); + transform: translate(0, -10px); + box-shadow: 0 5px 5px rgba(0,0,0,0.3); + } + 50% { + -webkit-transform: translate(0, -10px); + transform: translate(0, -10px); + box-shadow: 0 5px 5px rgba(0,0,0,0.3); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + box-shadow: 0 0 0 rgba(0,0,0,0.3); + } +} +.ld.ld-float-px { + -webkit-animation: ld-float-px 1s infinite; + animation: ld-float-px 1s infinite; +} +@keyframes ld-hit-px { + 0% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + -webkit-transform: scale(0) translate(0, 0) skewX(0); + transform: scale(0) translate(0, 0) skewX(0); + } + 20% { + -webkit-transform: scale(1) translate(0, 0) skewX(20deg); + transform: scale(1) translate(0, 0) skewX(20deg); + } + 50% { + animation-timing-function: cubic-bezier(1, 0, 1, 0.5); + -webkit-transform: scale(1) translate(0, 0) skewX(20deg); + transform: scale(1) translate(0, 0) skewX(20deg); + } + 100% { + -webkit-transform: scale(1) translate(0, 150px) skewX(20deg); + transform: scale(1) translate(0, 150px) skewX(20deg); + } +} +@-webkit-keyframes ld-hit-px { + 0% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + -webkit-transform: scale(0) translate(0, 0) skewX(0); + transform: scale(0) translate(0, 0) skewX(0); + } + 20% { + -webkit-transform: scale(1) translate(0, 0) skewX(20deg); + transform: scale(1) translate(0, 0) skewX(20deg); + } + 50% { + animation-timing-function: cubic-bezier(1, 0, 1, 0.5); + -webkit-transform: scale(1) translate(0, 0) skewX(20deg); + transform: scale(1) translate(0, 0) skewX(20deg); + } + 100% { + -webkit-transform: scale(1) translate(0, 150px) skewX(20deg); + transform: scale(1) translate(0, 150px) skewX(20deg); + } +} +.ld.ld-hit-px { + -webkit-animation: ld-hit-px 2s infinite; + animation: ld-hit-px 2s infinite; +} +@keyframes ld-jelly-px { + 0%, 16.6%, 33.3%, 50%, 66.6%, 83.3% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } + 16.6% { + -webkit-transform: translate(-30px, 0) skewX(30deg); + transform: translate(-30px, 0) skewX(30deg); + } + 33.3% { + -webkit-transform: translate(25px, 0) skewX(-20deg); + transform: translate(25px, 0) skewX(-20deg); + } + 50% { + -webkit-transform: translate(-12px, 0) skewX(10deg); + transform: translate(-12px, 0) skewX(10deg); + } + 66.6% { + -webkit-transform: translate(6px, 0) skewX(-5deg); + transform: translate(6px, 0) skewX(-5deg); + } + 83.3% { + -webkit-transform: translate(-2.5px, 0) skewX(2deg); + transform: translate(-2.5px, 0) skewX(2deg); + } + 100% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } +} +@-webkit-keyframes ld-jelly-px { + 0%, 16.6%, 33.3%, 50%, 66.6%, 83.3% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } + 16.6% { + -webkit-transform: translate(-30px, 0) skewX(30deg); + transform: translate(-30px, 0) skewX(30deg); + } + 33.3% { + -webkit-transform: translate(25px, 0) skewX(-20deg); + transform: translate(25px, 0) skewX(-20deg); + } + 50% { + -webkit-transform: translate(-12px, 0) skewX(10deg); + transform: translate(-12px, 0) skewX(10deg); + } + 66.6% { + -webkit-transform: translate(6px, 0) skewX(-5deg); + transform: translate(6px, 0) skewX(-5deg); + } + 83.3% { + -webkit-transform: translate(-2.5px, 0) skewX(2deg); + transform: translate(-2.5px, 0) skewX(2deg); + } + 100% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } +} +.ld.ld-jelly-px { + -webkit-animation: ld-jelly-px 1s infinite linear; + animation: ld-jelly-px 1s infinite linear; +} +@keyframes ld-jump-px { + 0%, 28%, 48%, 64%, 76%, 86%, 93%, 100% { + animation-timing-function: ease-out; + } + 14%, 38%, 56%, 70%, 81%, 90%, 97% { + animation-timing-function: ease-in; + } + 0% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 14% { + -webkit-transform: translateY(-27px); + transform: translateY(-27px); + } + 28% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 38% { + -webkit-transform: translateY(-20px); + transform: translateY(-20px); + } + 48% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 56% { + -webkit-transform: translateY(-16px); + transform: translateY(-16px); + } + 64% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 70% { + -webkit-transform: translateY(-12px); + transform: translateY(-12px); + } + 76% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 81% { + -webkit-transform: translateY(-7.5px); + transform: translateY(-7.5px); + } + 86% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 90% { + -webkit-transform: translateY(-3px); + transform: translateY(-3px); + } + 93% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 97% { + -webkit-transform: translateY(-1.5px); + transform: translateY(-1.5px); + } + 100% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } +} +@-webkit-keyframes ld-jump-px { + 0%, 28%, 48%, 64%, 76%, 86%, 93%, 100% { + animation-timing-function: ease-out; + } + 14%, 38%, 56%, 70%, 81%, 90%, 97% { + animation-timing-function: ease-in; + } + 0% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 14% { + -webkit-transform: translateY(-27px); + transform: translateY(-27px); + } + 28% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 38% { + -webkit-transform: translateY(-20px); + transform: translateY(-20px); + } + 48% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 56% { + -webkit-transform: translateY(-16px); + transform: translateY(-16px); + } + 64% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 70% { + -webkit-transform: translateY(-12px); + transform: translateY(-12px); + } + 76% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 81% { + -webkit-transform: translateY(-7.5px); + transform: translateY(-7.5px); + } + 86% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 90% { + -webkit-transform: translateY(-3px); + transform: translateY(-3px); + } + 93% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } + 97% { + -webkit-transform: translateY(-1.5px); + transform: translateY(-1.5px); + } + 100% { + -webkit-transform: translateY(0px); + transform: translateY(0px); + } +} +.ld.ld-jump-px { + -webkit-animation: ld-jump-px 1.5s ease-in infinite; + animation: ld-jump-px 1.5s ease-in infinite; +} +@keyframes ld-orbit-px { + 0% { + -webkit-transform: translate(30px, 0) rotate(0deg); + transform: translate(30px, 0) rotate(0deg); + } + 12.5% { + -webkit-transform: translate(21px, 21px) rotate(45deg); + transform: translate(21px, 21px) rotate(45deg); + } + 25% { + -webkit-transform: translate(0, 30px) rotate(90deg); + transform: translate(0, 30px) rotate(90deg); + } + 37.5% { + -webkit-transform: translate(-21px, 21px) rotate(135deg); + transform: translate(-21px, 21px) rotate(135deg); + } + 50% { + -webkit-transform: translate(-30px, 0) rotate(180deg); + transform: translate(-30px, 0) rotate(180deg); + } + 62.5% { + -webkit-transform: translate(-21px, -21px) rotate(225deg); + transform: translate(-21px, -21px) rotate(225deg); + } + 75% { + -webkit-transform: translate(0, -30px) rotate(270deg); + transform: translate(0, -30px) rotate(270deg); + } + 87.5% { + -webkit-transform: translate(21px, -21px) rotate(315deg); + transform: translate(21px, -21px) rotate(315deg); + } + 100% { + -webkit-transform: translate(30px, 0) rotate(360deg); + transform: translate(30px, 0) rotate(360deg); + } +} +@-webkit-keyframes ld-orbit-px { + 0% { + -webkit-transform: translate(30px, 0) rotate(0deg); + transform: translate(30px, 0) rotate(0deg); + } + 12.5% { + -webkit-transform: translate(21px, 21px) rotate(45deg); + transform: translate(21px, 21px) rotate(45deg); + } + 25% { + -webkit-transform: translate(0, 30px) rotate(90deg); + transform: translate(0, 30px) rotate(90deg); + } + 37.5% { + -webkit-transform: translate(-21px, 21px) rotate(135deg); + transform: translate(-21px, 21px) rotate(135deg); + } + 50% { + -webkit-transform: translate(-30px, 0) rotate(180deg); + transform: translate(-30px, 0) rotate(180deg); + } + 62.5% { + -webkit-transform: translate(-21px, -21px) rotate(225deg); + transform: translate(-21px, -21px) rotate(225deg); + } + 75% { + -webkit-transform: translate(0, -30px) rotate(270deg); + transform: translate(0, -30px) rotate(270deg); + } + 87.5% { + -webkit-transform: translate(21px, -21px) rotate(315deg); + transform: translate(21px, -21px) rotate(315deg); + } + 100% { + -webkit-transform: translate(30px, 0) rotate(360deg); + transform: translate(30px, 0) rotate(360deg); + } +} +.ld.ld-orbit-px { + -webkit-animation: ld-orbit-px 1s infinite linear; + animation: ld-orbit-px 1s infinite linear; +} +@keyframes ld-rush-px-rtl { + 0% { + -webkit-transform: translate(100px, 0) skewX(-45deg); + transform: translate(100px, 0) skewX(-45deg); + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 30% { + -webkit-transform: translate(-20px, 0) skewX(35deg); + transform: translate(-20px, 0) skewX(35deg); + } + 45% { + -webkit-transform: translate(10px, 0) skewX(-15deg); + transform: translate(10px, 0) skewX(-15deg); + } + 60% { + -webkit-transform: translate(-5px, 0) skewX(7deg); + transform: translate(-5px, 0) skewX(7deg); + } + 80% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } + 100% { + -webkit-transform: translate(-150px, 0) skewX(-45deg); + transform: translate(-150px, 0) skewX(-45deg); + } +} +@-webkit-keyframes ld-rush-px-rtl { + 0% { + -webkit-transform: translate(100px, 0) skewX(-45deg); + transform: translate(100px, 0) skewX(-45deg); + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 30% { + -webkit-transform: translate(-20px, 0) skewX(35deg); + transform: translate(-20px, 0) skewX(35deg); + } + 45% { + -webkit-transform: translate(10px, 0) skewX(-15deg); + transform: translate(10px, 0) skewX(-15deg); + } + 60% { + -webkit-transform: translate(-5px, 0) skewX(7deg); + transform: translate(-5px, 0) skewX(7deg); + } + 80% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } + 100% { + -webkit-transform: translate(-150px, 0) skewX(-45deg); + transform: translate(-150px, 0) skewX(-45deg); + } +} +.ld.ld-rush-px-rtl { + -webkit-animation: ld-rush-px-rtl 1.5s infinite linear; + animation: ld-rush-px-rtl 1.5s infinite linear; +} +@keyframes ld-rush-px-ltr { + 0% { + -webkit-transform: translate(-100px, 0) skewX(45deg); + transform: translate(-100px, 0) skewX(45deg); + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 30% { + -webkit-transform: translate(20px, 0) skewX(-35deg); + transform: translate(20px, 0) skewX(-35deg); + } + 45% { + -webkit-transform: translate(-10px, 0) skewX(15deg); + transform: translate(-10px, 0) skewX(15deg); + } + 60% { + -webkit-transform: translate(5px, 0) skewX(-7deg); + transform: translate(5px, 0) skewX(-7deg); + } + 80% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } + 100% { + -webkit-transform: translate(150px, 0) skewX(45deg); + transform: translate(150px, 0) skewX(45deg); + } +} +@-webkit-keyframes ld-rush-px-ltr { + 0% { + -webkit-transform: translate(-100px, 0) skewX(45deg); + transform: translate(-100px, 0) skewX(45deg); + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 30% { + -webkit-transform: translate(20px, 0) skewX(-35deg); + transform: translate(20px, 0) skewX(-35deg); + } + 45% { + -webkit-transform: translate(-10px, 0) skewX(15deg); + transform: translate(-10px, 0) skewX(15deg); + } + 60% { + -webkit-transform: translate(5px, 0) skewX(-7deg); + transform: translate(5px, 0) skewX(-7deg); + } + 80% { + -webkit-transform: translate(0, 0) skewX(0deg); + transform: translate(0, 0) skewX(0deg); + } + 100% { + -webkit-transform: translate(150px, 0) skewX(45deg); + transform: translate(150px, 0) skewX(45deg); + } +} +.ld.ld-rush-px-ltr { + -webkit-animation: ld-rush-px-ltr 1.5s infinite linear; + animation: ld-rush-px-ltr 1.5s infinite linear; +} +@keyframes ld-shake-px { + 0%, 16.6%, 33.3%, 50%, 66.6%, 83.3% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 16.6% { + -webkit-transform: translate(-35px, 0); + transform: translate(-35px, 0); + } + 33.3% { + -webkit-transform: translate(25px, 0); + transform: translate(25px, 0); + } + 50% { + -webkit-transform: translate(-12px, 0); + transform: translate(-12px, 0); + } + 66.6% { + -webkit-transform: translate(6px, 0); + transform: translate(6px, 0); + } + 83.3% { + -webkit-transform: translate(-2.5px, 0); + transform: translate(-2.5px, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-shake-px { + 0%, 16.6%, 33.3%, 50%, 66.6%, 83.3% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 16.6% { + -webkit-transform: translate(-35px, 0); + transform: translate(-35px, 0); + } + 33.3% { + -webkit-transform: translate(25px, 0); + transform: translate(25px, 0); + } + 50% { + -webkit-transform: translate(-12px, 0); + transform: translate(-12px, 0); + } + 66.6% { + -webkit-transform: translate(6px, 0); + transform: translate(6px, 0); + } + 83.3% { + -webkit-transform: translate(-2.5px, 0); + transform: translate(-2.5px, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-shake-px { + -webkit-animation: ld-shake-px 1s infinite linear; + animation: ld-shake-px 1s infinite linear; +} +@keyframes ld-slide-px-ltr { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(100px, 0); + transform: translate(100px, 0); + } + 50% { + -webkit-transform: translate(-100px, 0); + transform: translate(-100px, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-slide-px-ltr { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(100px, 0); + transform: translate(100px, 0); + } + 50% { + -webkit-transform: translate(-100px, 0); + transform: translate(-100px, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-slide-px-ltr { + -webkit-animation: ld-slide-px-ltr 1s infinite; + animation: ld-slide-px-ltr 1s infinite; +} +@keyframes ld-slide-px-rtl { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(-100px, 0); + transform: translate(-100px, 0); + } + 50% { + -webkit-transform: translate(100px, 0); + transform: translate(100px, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-slide-px-rtl { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(-100px, 0); + transform: translate(-100px, 0); + } + 50% { + -webkit-transform: translate(100px, 0); + transform: translate(100px, 0); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-slide-px-rtl { + -webkit-animation: ld-slide-px-rtl 1s infinite; + animation: ld-slide-px-rtl 1s infinite; +} +@keyframes ld-slide-px-btt { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 50% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-slide-px-btt { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 50% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-slide-px-btt { + -webkit-animation: ld-slide-px-btt 1s infinite; + animation: ld-slide-px-btt 1s infinite; +} +@keyframes ld-slide-px-ttb { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +@-webkit-keyframes ld-slide-px-ttb { + 0%, 100% { + animation-timing-function: cubic-bezier(0.5, 0, 1, 0.5); + } + 50% { + animation-timing-function: cubic-bezier(0, 0.5, 0.5, 1); + } + 0% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 49.9% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 100% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } +} +.ld.ld-slide-px-ttb { + -webkit-animation: ld-slide-px-ttb 1s infinite; + animation: ld-slide-px-ttb 1s infinite; +} +@keyframes ld-tremble-px { + 0% { + -webkit-transform: translate(1px, 1px); + transform: translate(1px, 1px); + } + 5% { + -webkit-transform: translate(0, 1px); + transform: translate(0, 1px); + } + 10% { + -webkit-transform: translate(1px, 2px); + transform: translate(1px, 2px); + } + 15% { + -webkit-transform: translate(2px, 1px); + transform: translate(2px, 1px); + } + 20% { + -webkit-transform: translate(3px, 0); + transform: translate(3px, 0); + } + 25% { + -webkit-transform: translate(1px, 2px); + transform: translate(1px, 2px); + } + 30% { + -webkit-transform: translate(1px, 3px); + transform: translate(1px, 3px); + } + 35% { + -webkit-transform: translate(0, 1px); + transform: translate(0, 1px); + } + 40% { + -webkit-transform: translate(1px, 1px); + transform: translate(1px, 1px); + } + 45% { + -webkit-transform: translate(1px, 0); + transform: translate(1px, 0); + } + 50% { + -webkit-transform: translate(2px, 1px); + transform: translate(2px, 1px); + } + 55% { + -webkit-transform: translate(1px, 2px); + transform: translate(1px, 2px); + } + 60% { + -webkit-transform: translate(3px, 1px); + transform: translate(3px, 1px); + } + 65% { + -webkit-transform: translate(0, 2px); + transform: translate(0, 2px); + } + 70% { + -webkit-transform: translate(3px, 0); + transform: translate(3px, 0); + } + 75% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 80% { + -webkit-transform: translate(2px, 3px); + transform: translate(2px, 3px); + } + 85% { + -webkit-transform: translate(1px, 0); + transform: translate(1px, 0); + } + 90% { + -webkit-transform: translate(0, 2px); + transform: translate(0, 2px); + } + 95% { + -webkit-transform: translate(3px, 2px); + transform: translate(3px, 2px); + } +} +@-webkit-keyframes ld-tremble-px { + 0% { + -webkit-transform: translate(1px, 1px); + transform: translate(1px, 1px); + } + 5% { + -webkit-transform: translate(0, 1px); + transform: translate(0, 1px); + } + 10% { + -webkit-transform: translate(1px, 2px); + transform: translate(1px, 2px); + } + 15% { + -webkit-transform: translate(2px, 1px); + transform: translate(2px, 1px); + } + 20% { + -webkit-transform: translate(3px, 0); + transform: translate(3px, 0); + } + 25% { + -webkit-transform: translate(1px, 2px); + transform: translate(1px, 2px); + } + 30% { + -webkit-transform: translate(1px, 3px); + transform: translate(1px, 3px); + } + 35% { + -webkit-transform: translate(0, 1px); + transform: translate(0, 1px); + } + 40% { + -webkit-transform: translate(1px, 1px); + transform: translate(1px, 1px); + } + 45% { + -webkit-transform: translate(1px, 0); + transform: translate(1px, 0); + } + 50% { + -webkit-transform: translate(2px, 1px); + transform: translate(2px, 1px); + } + 55% { + -webkit-transform: translate(1px, 2px); + transform: translate(1px, 2px); + } + 60% { + -webkit-transform: translate(3px, 1px); + transform: translate(3px, 1px); + } + 65% { + -webkit-transform: translate(0, 2px); + transform: translate(0, 2px); + } + 70% { + -webkit-transform: translate(3px, 0); + transform: translate(3px, 0); + } + 75% { + -webkit-transform: translate(0, 0); + transform: translate(0, 0); + } + 80% { + -webkit-transform: translate(2px, 3px); + transform: translate(2px, 3px); + } + 85% { + -webkit-transform: translate(1px, 0); + transform: translate(1px, 0); + } + 90% { + -webkit-transform: translate(0, 2px); + transform: translate(0, 2px); + } + 95% { + -webkit-transform: translate(3px, 2px); + transform: translate(3px, 2px); + } +} +.ld.ld-tremble-px { + -webkit-animation: ld-tremble-px 1s infinite; + animation: ld-tremble-px 1s infinite; +} +@keyframes ld-wander-px-h { + 0% { + -webkit-transform: translate(-35px, 0); + transform: translate(-35px, 0); + } + 50% { + -webkit-transform: translate(35px, 0); + transform: translate(35px, 0); + } + 100% { + -webkit-transform: translate(-35px, 0); + transform: translate(-35px, 0); + } +} +@-webkit-keyframes ld-wander-px-h { + 0% { + -webkit-transform: translate(-35px, 0); + transform: translate(-35px, 0); + } + 50% { + -webkit-transform: translate(35px, 0); + transform: translate(35px, 0); + } + 100% { + -webkit-transform: translate(-35px, 0); + transform: translate(-35px, 0); + } +} +.ld.ld-wander-px-h { + -webkit-animation: ld-wander-px-h 1s infinite ease-out; + animation: ld-wander-px-h 1s infinite ease-out; +} +@keyframes ld-wander-px-v { + 0% { + -webkit-transform: translate(0, -35px); + transform: translate(0, -35px); + } + 50% { + -webkit-transform: translate(0, 35px); + transform: translate(0, 35px); + } + 100% { + -webkit-transform: translate(0, -35px); + transform: translate(0, -35px); + } +} +@-webkit-keyframes ld-wander-px-v { + 0% { + -webkit-transform: translate(0, -35px); + transform: translate(0, -35px); + } + 50% { + -webkit-transform: translate(0, 35px); + transform: translate(0, 35px); + } + 100% { + -webkit-transform: translate(0, -35px); + transform: translate(0, -35px); + } +} +.ld.ld-wander-px-v { + -webkit-animation: ld-wander-px-v 1s infinite ease-out; + animation: ld-wander-px-v 1s infinite ease-out; +} +@keyframes ld-jingle-px { + 0% { + -webkit-transform: translate(0, -40px) rotate(0deg) translate(0, 40px); + transform: translate(0, -40px) rotate(0deg) translate(0, 40px); + } + 4% { + -webkit-transform: translate(0, -40px) rotate(11deg) translate(0, 40px); + transform: translate(0, -40px) rotate(11deg) translate(0, 40px); + } + 10% { + -webkit-transform: translate(0, -40px) rotate(15deg) translate(0, 40px); + transform: translate(0, -40px) rotate(15deg) translate(0, 40px); + } + 18% { + -webkit-transform: translate(0, -40px) rotate(-11deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-11deg) translate(0, 40px); + } + 20% { + -webkit-transform: translate(0, -40px) rotate(-13deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-13deg) translate(0, 40px); + } + 21% { + -webkit-transform: translate(0, -40px) rotate(-12deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-12deg) translate(0, 40px); + } + 22% { + -webkit-transform: translate(0, -40px) rotate(-10deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-10deg) translate(0, 40px); + } + 24% { + -webkit-transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + } + 26% { + -webkit-transform: translate(0, -40px) rotate(3deg) translate(0, 40px); + transform: translate(0, -40px) rotate(3deg) translate(0, 40px); + } + 28% { + -webkit-transform: translate(0, -40px) rotate(9deg) translate(0, 40px); + transform: translate(0, -40px) rotate(9deg) translate(0, 40px); + } + 30% { + -webkit-transform: translate(0, -40px) rotate(10deg) translate(0, 40px); + transform: translate(0, -40px) rotate(10deg) translate(0, 40px); + } + 31% { + -webkit-transform: translate(0, -40px) rotate(9deg) translate(0, 40px); + transform: translate(0, -40px) rotate(9deg) translate(0, 40px); + } + 33% { + -webkit-transform: translate(0, -40px) rotate(5deg) translate(0, 40px); + transform: translate(0, -40px) rotate(5deg) translate(0, 40px); + } + 34% { + -webkit-transform: translate(0, -40px) rotate(1deg) translate(0, 40px); + transform: translate(0, -40px) rotate(1deg) translate(0, 40px); + } + 36% { + -webkit-transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + } + 39% { + -webkit-transform: translate(0, -40px) rotate(-8deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-8deg) translate(0, 40px); + } + 40% { + -webkit-transform: translate(0, -40px) rotate(-7deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-7deg) translate(0, 40px); + } + 44% { + -webkit-transform: translate(0, -40px) rotate(3deg) translate(0, 40px); + transform: translate(0, -40px) rotate(3deg) translate(0, 40px); + } + 47% { + -webkit-transform: translate(0, -40px) rotate(7deg) translate(0, 40px); + transform: translate(0, -40px) rotate(7deg) translate(0, 40px); + } + 56% { + -webkit-transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + } + 63% { + -webkit-transform: translate(0, -40px) rotate(1deg) translate(0, 40px); + transform: translate(0, -40px) rotate(1deg) translate(0, 40px); + } + 75% { + -webkit-transform: translate(0, -40px) rotate(-1deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-1deg) translate(0, 40px); + } + 100% { + -webkit-transform: translate(0, -40px) rotate(0deg) translate(0, 40px); + transform: translate(0, -40px) rotate(0deg) translate(0, 40px); + } +} +@-webkit-keyframes ld-jingle-px { + 0% { + -webkit-transform: translate(0, -40px) rotate(0deg) translate(0, 40px); + transform: translate(0, -40px) rotate(0deg) translate(0, 40px); + } + 4% { + -webkit-transform: translate(0, -40px) rotate(11deg) translate(0, 40px); + transform: translate(0, -40px) rotate(11deg) translate(0, 40px); + } + 10% { + -webkit-transform: translate(0, -40px) rotate(15deg) translate(0, 40px); + transform: translate(0, -40px) rotate(15deg) translate(0, 40px); + } + 18% { + -webkit-transform: translate(0, -40px) rotate(-11deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-11deg) translate(0, 40px); + } + 20% { + -webkit-transform: translate(0, -40px) rotate(-13deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-13deg) translate(0, 40px); + } + 21% { + -webkit-transform: translate(0, -40px) rotate(-12deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-12deg) translate(0, 40px); + } + 22% { + -webkit-transform: translate(0, -40px) rotate(-10deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-10deg) translate(0, 40px); + } + 24% { + -webkit-transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + } + 26% { + -webkit-transform: translate(0, -40px) rotate(3deg) translate(0, 40px); + transform: translate(0, -40px) rotate(3deg) translate(0, 40px); + } + 28% { + -webkit-transform: translate(0, -40px) rotate(9deg) translate(0, 40px); + transform: translate(0, -40px) rotate(9deg) translate(0, 40px); + } + 30% { + -webkit-transform: translate(0, -40px) rotate(10deg) translate(0, 40px); + transform: translate(0, -40px) rotate(10deg) translate(0, 40px); + } + 31% { + -webkit-transform: translate(0, -40px) rotate(9deg) translate(0, 40px); + transform: translate(0, -40px) rotate(9deg) translate(0, 40px); + } + 33% { + -webkit-transform: translate(0, -40px) rotate(5deg) translate(0, 40px); + transform: translate(0, -40px) rotate(5deg) translate(0, 40px); + } + 34% { + -webkit-transform: translate(0, -40px) rotate(1deg) translate(0, 40px); + transform: translate(0, -40px) rotate(1deg) translate(0, 40px); + } + 36% { + -webkit-transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + } + 39% { + -webkit-transform: translate(0, -40px) rotate(-8deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-8deg) translate(0, 40px); + } + 40% { + -webkit-transform: translate(0, -40px) rotate(-7deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-7deg) translate(0, 40px); + } + 44% { + -webkit-transform: translate(0, -40px) rotate(3deg) translate(0, 40px); + transform: translate(0, -40px) rotate(3deg) translate(0, 40px); + } + 47% { + -webkit-transform: translate(0, -40px) rotate(7deg) translate(0, 40px); + transform: translate(0, -40px) rotate(7deg) translate(0, 40px); + } + 56% { + -webkit-transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-5deg) translate(0, 40px); + } + 63% { + -webkit-transform: translate(0, -40px) rotate(1deg) translate(0, 40px); + transform: translate(0, -40px) rotate(1deg) translate(0, 40px); + } + 75% { + -webkit-transform: translate(0, -40px) rotate(-1deg) translate(0, 40px); + transform: translate(0, -40px) rotate(-1deg) translate(0, 40px); + } + 100% { + -webkit-transform: translate(0, -40px) rotate(0deg) translate(0, 40px); + transform: translate(0, -40px) rotate(0deg) translate(0, 40px); + } +} +.ld.ld-jingle-px { + -webkit-animation: ld-jingle-px 1s infinite; + animation: ld-jingle-px 1s infinite; +} +@keyframes ld-swim-px { + 0% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } + 12.5% { + -webkit-transform: translate(1px, -2px) rotate(3deg); + transform: translate(1px, -2px) rotate(3deg); + } + 25% { + -webkit-transform: translate(0, -3px) rotate(6deg); + transform: translate(0, -3px) rotate(6deg); + } + 37.5% { + -webkit-transform: translate(-1px, -2px) rotate(3deg); + transform: translate(-1px, -2px) rotate(3deg); + } + 50% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } + 62.5% { + -webkit-transform: translate(1px, 2px) rotate(-3deg); + transform: translate(1px, 2px) rotate(-3deg); + } + 75% { + -webkit-transform: translate(0, 3px) rotate(-6deg); + transform: translate(0, 3px) rotate(-6deg); + } + 87.5% { + -webkit-transform: translate(-1px, 2px) rotate(-3deg); + transform: translate(-1px, 2px) rotate(-3deg); + } + 100% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } +} +@-webkit-keyframes ld-swim-px { + 0% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } + 12.5% { + -webkit-transform: translate(1px, -2px) rotate(3deg); + transform: translate(1px, -2px) rotate(3deg); + } + 25% { + -webkit-transform: translate(0, -3px) rotate(6deg); + transform: translate(0, -3px) rotate(6deg); + } + 37.5% { + -webkit-transform: translate(-1px, -2px) rotate(3deg); + transform: translate(-1px, -2px) rotate(3deg); + } + 50% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } + 62.5% { + -webkit-transform: translate(1px, 2px) rotate(-3deg); + transform: translate(1px, 2px) rotate(-3deg); + } + 75% { + -webkit-transform: translate(0, 3px) rotate(-6deg); + transform: translate(0, 3px) rotate(-6deg); + } + 87.5% { + -webkit-transform: translate(-1px, 2px) rotate(-3deg); + transform: translate(-1px, 2px) rotate(-3deg); + } + 100% { + -webkit-transform: translate(0, 0) rotate(0deg); + transform: translate(0, 0) rotate(0deg); + } +} +.ld.ld-swim-px { + -webkit-animation: ld-swim-px 3s infinite linear; + animation: ld-swim-px 3s infinite linear; +} +@keyframes ld-leaf-px { + 0% { + -webkit-transform: translate(-14.7px, -117px) rotate(-0.3deg); + transform: translate(-14.7px, -117px) rotate(-0.3deg); + } + 1% { + -webkit-transform: translate(-14.399999999999999px, -112.5px) rotate(-0.6deg); + transform: translate(-14.399999999999999px, -112.5px) rotate(-0.6deg); + } + 2% { + -webkit-transform: translate(-13.8px, -102.00000000000001px) rotate(-1.2deg); + transform: translate(-13.8px, -102.00000000000001px) rotate(-1.2deg); + } + 3% { + -webkit-transform: translate(-13.5px, -100.5px) rotate(-1.5deg); + transform: translate(-13.5px, -100.5px) rotate(-1.5deg); + } + 5% { + -webkit-transform: translate(-7.199999999999999px, -87px) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999px, -87px) rotate(-7.800000000000001deg); + } + 7% { + -webkit-transform: translate(5.399999999999999px, -79.5px) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999px, -79.5px) rotate(-20.400000000000002deg); + } + 10% { + -webkit-transform: translate(12.9px, -76.5px) rotate(-27.900000000000002deg); + transform: translate(12.9px, -76.5px) rotate(-27.900000000000002deg); + } + 12% { + -webkit-transform: translate(14.399999999999999px, -75px) rotate(-29.4deg); + transform: translate(14.399999999999999px, -75px) rotate(-29.4deg); + } + 13% { + -webkit-transform: translate(14.7px, -75px) rotate(-29.7deg); + transform: translate(14.7px, -75px) rotate(-29.7deg); + } + 14% { + -webkit-transform: translate(15px, -75px) rotate(-30deg); + transform: translate(15px, -75px) rotate(-30deg); + } + 15% { + -webkit-transform: translate(14.399999999999999px, -69px) rotate(0.6deg); + transform: translate(14.399999999999999px, -69px) rotate(0.6deg); + } + 16% { + -webkit-transform: translate(13.8px, -58.5px) rotate(1.2deg); + transform: translate(13.8px, -58.5px) rotate(1.2deg); + } + 19% { + -webkit-transform: translate(7.199999999999999px, -45px) rotate(7.800000000000001deg); + transform: translate(7.199999999999999px, -45px) rotate(7.800000000000001deg); + } + 21% { + -webkit-transform: translate(-5.399999999999999px, -37.5px) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999px, -37.5px) rotate(20.400000000000002deg); + } + 24% { + -webkit-transform: translate(-12.9px, -33px) rotate(27.900000000000002deg); + transform: translate(-12.9px, -33px) rotate(27.900000000000002deg); + } + 26% { + -webkit-transform: translate(-14.399999999999999px, -33px) rotate(29.4deg); + transform: translate(-14.399999999999999px, -33px) rotate(29.4deg); + } + 27% { + -webkit-transform: translate(-14.7px, -31.5px) rotate(29.7deg); + transform: translate(-14.7px, -31.5px) rotate(29.7deg); + } + 28% { + -webkit-transform: translate(-15px, -31.5px) rotate(30deg); + transform: translate(-15px, -31.5px) rotate(30deg); + } + 29% { + -webkit-transform: translate(-14.399999999999999px, -27px) rotate(-0.6deg); + transform: translate(-14.399999999999999px, -27px) rotate(-0.6deg); + } + 30% { + -webkit-transform: translate(-13.8px, -16.5px) rotate(-1.2deg); + transform: translate(-13.8px, -16.5px) rotate(-1.2deg); + } + 31% { + -webkit-transform: translate(-13.5px, -15px) rotate(-1.5deg); + transform: translate(-13.5px, -15px) rotate(-1.5deg); + } + 33% { + -webkit-transform: translate(-7.199999999999999px, -1.5px) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999px, -1.5px) rotate(-7.800000000000001deg); + } + 36% { + -webkit-transform: translate(5.399999999999999px, 4.5px) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999px, 4.5px) rotate(-20.400000000000002deg); + } + 38% { + -webkit-transform: translate(12.9px, 9px) rotate(-27.900000000000002deg); + transform: translate(12.9px, 9px) rotate(-27.900000000000002deg); + } + 40% { + -webkit-transform: translate(14.399999999999999px, 10.500000000000002px) rotate(-29.4deg); + transform: translate(14.399999999999999px, 10.500000000000002px) rotate(-29.4deg); + } + 41% { + -webkit-transform: translate(14.7px, 10.500000000000002px) rotate(-29.7deg); + transform: translate(14.7px, 10.500000000000002px) rotate(-29.7deg); + } + 42% { + -webkit-transform: translate(15px, 10.500000000000002px) rotate(-30deg); + transform: translate(15px, 10.500000000000002px) rotate(-30deg); + } + 43% { + -webkit-transform: translate(15px, 10.500000000000002px) rotate(-30deg); + transform: translate(15px, 10.500000000000002px) rotate(-30deg); + } + 43% { + -webkit-transform: translate(14.7px, 10.500000000000002px) rotate(0.3deg); + transform: translate(14.7px, 10.500000000000002px) rotate(0.3deg); + } + 43% { + -webkit-transform: translate(14.399999999999999px, 16.5px) rotate(0.6deg); + transform: translate(14.399999999999999px, 16.5px) rotate(0.6deg); + } + 45% { + -webkit-transform: translate(13.8px, 25.500000000000004px) rotate(1.2deg); + transform: translate(13.8px, 25.500000000000004px) rotate(1.2deg); + } + 45% { + -webkit-transform: translate(13.5px, 27px) rotate(1.5deg); + transform: translate(13.5px, 27px) rotate(1.5deg); + } + 48% { + -webkit-transform: translate(7.199999999999999px, 40.5px) rotate(7.800000000000001deg); + transform: translate(7.199999999999999px, 40.5px) rotate(7.800000000000001deg); + } + 50% { + -webkit-transform: translate(-5.399999999999999px, 48px) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999px, 48px) rotate(20.400000000000002deg); + } + 52% { + -webkit-transform: translate(-12.9px, 51.00000000000001px) rotate(27.900000000000002deg); + transform: translate(-12.9px, 51.00000000000001px) rotate(27.900000000000002deg); + } + 54% { + -webkit-transform: translate(-14.399999999999999px, 52.5px) rotate(29.4deg); + transform: translate(-14.399999999999999px, 52.5px) rotate(29.4deg); + } + 56% { + -webkit-transform: translate(-14.7px, 54px) rotate(29.7deg); + transform: translate(-14.7px, 54px) rotate(29.7deg); + } + 57% { + -webkit-transform: translate(-14.7px, 54px) rotate(-0.3deg); + transform: translate(-14.7px, 54px) rotate(-0.3deg); + } + 58% { + -webkit-transform: translate(-14.399999999999999px, 58.5px) rotate(-0.6deg); + transform: translate(-14.399999999999999px, 58.5px) rotate(-0.6deg); + } + 59% { + -webkit-transform: translate(-13.5px, 70.5px) rotate(-1.5deg); + transform: translate(-13.5px, 70.5px) rotate(-1.5deg); + } + 62% { + -webkit-transform: translate(-7.199999999999999px, 84.00000000000001px) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999px, 84.00000000000001px) rotate(-7.800000000000001deg); + } + 64% { + -webkit-transform: translate(5.399999999999999px, 91.5px) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999px, 91.5px) rotate(-20.400000000000002deg); + } + 67% { + -webkit-transform: translate(12.9px, 94.5px) rotate(-27.900000000000002deg); + transform: translate(12.9px, 94.5px) rotate(-27.900000000000002deg); + } + 69% { + -webkit-transform: translate(14.399999999999999px, 96px) rotate(-29.4deg); + transform: translate(14.399999999999999px, 96px) rotate(-29.4deg); + } + 70% { + -webkit-transform: translate(14.7px, 96px) rotate(-29.7deg); + transform: translate(14.7px, 96px) rotate(-29.7deg); + } + 71% { + -webkit-transform: translate(15px, 96px) rotate(-30deg); + transform: translate(15px, 96px) rotate(-30deg); + } + 72% { + -webkit-transform: translate(14.399999999999999px, 102.00000000000001px) rotate(0.6deg); + transform: translate(14.399999999999999px, 102.00000000000001px) rotate(0.6deg); + } + 73% { + -webkit-transform: translate(13.8px, 111px) rotate(1.2deg); + transform: translate(13.8px, 111px) rotate(1.2deg); + } + 74% { + -webkit-transform: translate(13.5px, 112.5px) rotate(1.5deg); + transform: translate(13.5px, 112.5px) rotate(1.5deg); + } + 76% { + -webkit-transform: translate(7.199999999999999px, 126px) rotate(7.800000000000001deg); + transform: translate(7.199999999999999px, 126px) rotate(7.800000000000001deg); + } + 79% { + -webkit-transform: translate(-5.399999999999999px, 133.5px) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999px, 133.5px) rotate(20.400000000000002deg); + } + 81% { + -webkit-transform: translate(-12.9px, 138px) rotate(27.900000000000002deg); + transform: translate(-12.9px, 138px) rotate(27.900000000000002deg); + } + 83% { + -webkit-transform: translate(-14.399999999999999px, 139.5px) rotate(29.4deg); + transform: translate(-14.399999999999999px, 139.5px) rotate(29.4deg); + } + 84% { + -webkit-transform: translate(-14.7px, 139.5px) rotate(29.7deg); + transform: translate(-14.7px, 139.5px) rotate(29.7deg); + } + 85% { + -webkit-transform: translate(-15px, 139.5px) rotate(30deg); + transform: translate(-15px, 139.5px) rotate(30deg); + } + 86% { + -webkit-transform: translate(-14.7px, 139.5px) rotate(-0.3deg); + transform: translate(-14.7px, 139.5px) rotate(-0.3deg); + } + 86% { + -webkit-transform: translate(-14.399999999999999px, 144px) rotate(-0.6deg); + transform: translate(-14.399999999999999px, 144px) rotate(-0.6deg); + } + 88% { + -webkit-transform: translate(-13.5px, 156px) rotate(-1.5deg); + transform: translate(-13.5px, 156px) rotate(-1.5deg); + } + 90% { + -webkit-transform: translate(-7.199999999999999px, 169.49999999999997px) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999px, 169.49999999999997px) rotate(-7.800000000000001deg); + } + 93% { + -webkit-transform: translate(5.399999999999999px, 177px) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999px, 177px) rotate(-20.400000000000002deg); + } + 95% { + -webkit-transform: translate(12.9px, 180px) rotate(-27.900000000000002deg); + transform: translate(12.9px, 180px) rotate(-27.900000000000002deg); + } + 97% { + -webkit-transform: translate(14.399999999999999px, 181.5px) rotate(-29.4deg); + transform: translate(14.399999999999999px, 181.5px) rotate(-29.4deg); + } + 99% { + -webkit-transform: translate(14.7px, 181.5px) rotate(-29.7deg); + transform: translate(14.7px, 181.5px) rotate(-29.7deg); + } + 100% { + -webkit-transform: translate(15px, 181.5px) rotate(-30deg); + transform: translate(15px, 181.5px) rotate(-30deg); + } +} +@-webkit-keyframes ld-leaf-px { + 0% { + -webkit-transform: translate(-14.7px, -117px) rotate(-0.3deg); + transform: translate(-14.7px, -117px) rotate(-0.3deg); + } + 1% { + -webkit-transform: translate(-14.399999999999999px, -112.5px) rotate(-0.6deg); + transform: translate(-14.399999999999999px, -112.5px) rotate(-0.6deg); + } + 2% { + -webkit-transform: translate(-13.8px, -102.00000000000001px) rotate(-1.2deg); + transform: translate(-13.8px, -102.00000000000001px) rotate(-1.2deg); + } + 3% { + -webkit-transform: translate(-13.5px, -100.5px) rotate(-1.5deg); + transform: translate(-13.5px, -100.5px) rotate(-1.5deg); + } + 5% { + -webkit-transform: translate(-7.199999999999999px, -87px) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999px, -87px) rotate(-7.800000000000001deg); + } + 7% { + -webkit-transform: translate(5.399999999999999px, -79.5px) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999px, -79.5px) rotate(-20.400000000000002deg); + } + 10% { + -webkit-transform: translate(12.9px, -76.5px) rotate(-27.900000000000002deg); + transform: translate(12.9px, -76.5px) rotate(-27.900000000000002deg); + } + 12% { + -webkit-transform: translate(14.399999999999999px, -75px) rotate(-29.4deg); + transform: translate(14.399999999999999px, -75px) rotate(-29.4deg); + } + 13% { + -webkit-transform: translate(14.7px, -75px) rotate(-29.7deg); + transform: translate(14.7px, -75px) rotate(-29.7deg); + } + 14% { + -webkit-transform: translate(15px, -75px) rotate(-30deg); + transform: translate(15px, -75px) rotate(-30deg); + } + 15% { + -webkit-transform: translate(14.399999999999999px, -69px) rotate(0.6deg); + transform: translate(14.399999999999999px, -69px) rotate(0.6deg); + } + 16% { + -webkit-transform: translate(13.8px, -58.5px) rotate(1.2deg); + transform: translate(13.8px, -58.5px) rotate(1.2deg); + } + 19% { + -webkit-transform: translate(7.199999999999999px, -45px) rotate(7.800000000000001deg); + transform: translate(7.199999999999999px, -45px) rotate(7.800000000000001deg); + } + 21% { + -webkit-transform: translate(-5.399999999999999px, -37.5px) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999px, -37.5px) rotate(20.400000000000002deg); + } + 24% { + -webkit-transform: translate(-12.9px, -33px) rotate(27.900000000000002deg); + transform: translate(-12.9px, -33px) rotate(27.900000000000002deg); + } + 26% { + -webkit-transform: translate(-14.399999999999999px, -33px) rotate(29.4deg); + transform: translate(-14.399999999999999px, -33px) rotate(29.4deg); + } + 27% { + -webkit-transform: translate(-14.7px, -31.5px) rotate(29.7deg); + transform: translate(-14.7px, -31.5px) rotate(29.7deg); + } + 28% { + -webkit-transform: translate(-15px, -31.5px) rotate(30deg); + transform: translate(-15px, -31.5px) rotate(30deg); + } + 29% { + -webkit-transform: translate(-14.399999999999999px, -27px) rotate(-0.6deg); + transform: translate(-14.399999999999999px, -27px) rotate(-0.6deg); + } + 30% { + -webkit-transform: translate(-13.8px, -16.5px) rotate(-1.2deg); + transform: translate(-13.8px, -16.5px) rotate(-1.2deg); + } + 31% { + -webkit-transform: translate(-13.5px, -15px) rotate(-1.5deg); + transform: translate(-13.5px, -15px) rotate(-1.5deg); + } + 33% { + -webkit-transform: translate(-7.199999999999999px, -1.5px) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999px, -1.5px) rotate(-7.800000000000001deg); + } + 36% { + -webkit-transform: translate(5.399999999999999px, 4.5px) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999px, 4.5px) rotate(-20.400000000000002deg); + } + 38% { + -webkit-transform: translate(12.9px, 9px) rotate(-27.900000000000002deg); + transform: translate(12.9px, 9px) rotate(-27.900000000000002deg); + } + 40% { + -webkit-transform: translate(14.399999999999999px, 10.500000000000002px) rotate(-29.4deg); + transform: translate(14.399999999999999px, 10.500000000000002px) rotate(-29.4deg); + } + 41% { + -webkit-transform: translate(14.7px, 10.500000000000002px) rotate(-29.7deg); + transform: translate(14.7px, 10.500000000000002px) rotate(-29.7deg); + } + 42% { + -webkit-transform: translate(15px, 10.500000000000002px) rotate(-30deg); + transform: translate(15px, 10.500000000000002px) rotate(-30deg); + } + 43% { + -webkit-transform: translate(15px, 10.500000000000002px) rotate(-30deg); + transform: translate(15px, 10.500000000000002px) rotate(-30deg); + } + 43% { + -webkit-transform: translate(14.7px, 10.500000000000002px) rotate(0.3deg); + transform: translate(14.7px, 10.500000000000002px) rotate(0.3deg); + } + 43% { + -webkit-transform: translate(14.399999999999999px, 16.5px) rotate(0.6deg); + transform: translate(14.399999999999999px, 16.5px) rotate(0.6deg); + } + 45% { + -webkit-transform: translate(13.8px, 25.500000000000004px) rotate(1.2deg); + transform: translate(13.8px, 25.500000000000004px) rotate(1.2deg); + } + 45% { + -webkit-transform: translate(13.5px, 27px) rotate(1.5deg); + transform: translate(13.5px, 27px) rotate(1.5deg); + } + 48% { + -webkit-transform: translate(7.199999999999999px, 40.5px) rotate(7.800000000000001deg); + transform: translate(7.199999999999999px, 40.5px) rotate(7.800000000000001deg); + } + 50% { + -webkit-transform: translate(-5.399999999999999px, 48px) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999px, 48px) rotate(20.400000000000002deg); + } + 52% { + -webkit-transform: translate(-12.9px, 51.00000000000001px) rotate(27.900000000000002deg); + transform: translate(-12.9px, 51.00000000000001px) rotate(27.900000000000002deg); + } + 54% { + -webkit-transform: translate(-14.399999999999999px, 52.5px) rotate(29.4deg); + transform: translate(-14.399999999999999px, 52.5px) rotate(29.4deg); + } + 56% { + -webkit-transform: translate(-14.7px, 54px) rotate(29.7deg); + transform: translate(-14.7px, 54px) rotate(29.7deg); + } + 57% { + -webkit-transform: translate(-14.7px, 54px) rotate(-0.3deg); + transform: translate(-14.7px, 54px) rotate(-0.3deg); + } + 58% { + -webkit-transform: translate(-14.399999999999999px, 58.5px) rotate(-0.6deg); + transform: translate(-14.399999999999999px, 58.5px) rotate(-0.6deg); + } + 59% { + -webkit-transform: translate(-13.5px, 70.5px) rotate(-1.5deg); + transform: translate(-13.5px, 70.5px) rotate(-1.5deg); + } + 62% { + -webkit-transform: translate(-7.199999999999999px, 84.00000000000001px) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999px, 84.00000000000001px) rotate(-7.800000000000001deg); + } + 64% { + -webkit-transform: translate(5.399999999999999px, 91.5px) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999px, 91.5px) rotate(-20.400000000000002deg); + } + 67% { + -webkit-transform: translate(12.9px, 94.5px) rotate(-27.900000000000002deg); + transform: translate(12.9px, 94.5px) rotate(-27.900000000000002deg); + } + 69% { + -webkit-transform: translate(14.399999999999999px, 96px) rotate(-29.4deg); + transform: translate(14.399999999999999px, 96px) rotate(-29.4deg); + } + 70% { + -webkit-transform: translate(14.7px, 96px) rotate(-29.7deg); + transform: translate(14.7px, 96px) rotate(-29.7deg); + } + 71% { + -webkit-transform: translate(15px, 96px) rotate(-30deg); + transform: translate(15px, 96px) rotate(-30deg); + } + 72% { + -webkit-transform: translate(14.399999999999999px, 102.00000000000001px) rotate(0.6deg); + transform: translate(14.399999999999999px, 102.00000000000001px) rotate(0.6deg); + } + 73% { + -webkit-transform: translate(13.8px, 111px) rotate(1.2deg); + transform: translate(13.8px, 111px) rotate(1.2deg); + } + 74% { + -webkit-transform: translate(13.5px, 112.5px) rotate(1.5deg); + transform: translate(13.5px, 112.5px) rotate(1.5deg); + } + 76% { + -webkit-transform: translate(7.199999999999999px, 126px) rotate(7.800000000000001deg); + transform: translate(7.199999999999999px, 126px) rotate(7.800000000000001deg); + } + 79% { + -webkit-transform: translate(-5.399999999999999px, 133.5px) rotate(20.400000000000002deg); + transform: translate(-5.399999999999999px, 133.5px) rotate(20.400000000000002deg); + } + 81% { + -webkit-transform: translate(-12.9px, 138px) rotate(27.900000000000002deg); + transform: translate(-12.9px, 138px) rotate(27.900000000000002deg); + } + 83% { + -webkit-transform: translate(-14.399999999999999px, 139.5px) rotate(29.4deg); + transform: translate(-14.399999999999999px, 139.5px) rotate(29.4deg); + } + 84% { + -webkit-transform: translate(-14.7px, 139.5px) rotate(29.7deg); + transform: translate(-14.7px, 139.5px) rotate(29.7deg); + } + 85% { + -webkit-transform: translate(-15px, 139.5px) rotate(30deg); + transform: translate(-15px, 139.5px) rotate(30deg); + } + 86% { + -webkit-transform: translate(-14.7px, 139.5px) rotate(-0.3deg); + transform: translate(-14.7px, 139.5px) rotate(-0.3deg); + } + 86% { + -webkit-transform: translate(-14.399999999999999px, 144px) rotate(-0.6deg); + transform: translate(-14.399999999999999px, 144px) rotate(-0.6deg); + } + 88% { + -webkit-transform: translate(-13.5px, 156px) rotate(-1.5deg); + transform: translate(-13.5px, 156px) rotate(-1.5deg); + } + 90% { + -webkit-transform: translate(-7.199999999999999px, 169.49999999999997px) rotate(-7.800000000000001deg); + transform: translate(-7.199999999999999px, 169.49999999999997px) rotate(-7.800000000000001deg); + } + 93% { + -webkit-transform: translate(5.399999999999999px, 177px) rotate(-20.400000000000002deg); + transform: translate(5.399999999999999px, 177px) rotate(-20.400000000000002deg); + } + 95% { + -webkit-transform: translate(12.9px, 180px) rotate(-27.900000000000002deg); + transform: translate(12.9px, 180px) rotate(-27.900000000000002deg); + } + 97% { + -webkit-transform: translate(14.399999999999999px, 181.5px) rotate(-29.4deg); + transform: translate(14.399999999999999px, 181.5px) rotate(-29.4deg); + } + 99% { + -webkit-transform: translate(14.7px, 181.5px) rotate(-29.7deg); + transform: translate(14.7px, 181.5px) rotate(-29.7deg); + } + 100% { + -webkit-transform: translate(15px, 181.5px) rotate(-30deg); + transform: translate(15px, 181.5px) rotate(-30deg); + } +} +.ld.ld-leaf-px { + -webkit-animation: ld-leaf-px 4s infinite cubic-bezier(0.1, 0.5, 0.1, 0.5); + animation: ld-leaf-px 4s infinite cubic-bezier(0.1, 0.5, 0.1, 0.5); +} +@keyframes ld-slot-px { + 0% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 9.09% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 9.1% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 16.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 17% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 23.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 23.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 29.59% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 29.6% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 34.49% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 34.5% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 38.49% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 38.5% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 41.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 41.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 44.39% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 44.4% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 46.29% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 46.3% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 47.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 47.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 48.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 48.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.39% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 49.4% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 49.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 50.190000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 50.59% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50.6% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 51.190000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 51.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 52.190000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 52.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 53.690000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 53.7% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 55.59% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 55.6% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 58.190000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 58.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 61.49% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 61.5% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 65.49% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 65.5% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 70.39% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 70.4% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 76.19% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 76.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 82.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 83% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 90.89% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 90.9% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 99.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 100% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } +} +@-webkit-keyframes ld-slot-px { + 0% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 9.09% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 9.1% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 16.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 17% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 23.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 23.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 29.59% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 29.6% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 34.49% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 34.5% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 38.49% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 38.5% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 41.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 41.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 44.39% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 44.4% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 46.29% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 46.3% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 47.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 47.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 48.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 48.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.39% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 49.4% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.79% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 49.8% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 49.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 50.190000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 50.59% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 50.6% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 51.190000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 51.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 52.190000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 52.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 53.690000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 53.7% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 55.59% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 55.6% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 58.190000000000005% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 58.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 61.49% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 61.5% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 65.49% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 65.5% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 70.39% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 70.4% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 76.19% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 76.2% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 82.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 83% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 90.89% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 90.9% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } + 99.99% { + -webkit-transform: translate(0, 100px); + transform: translate(0, 100px); + } + 100% { + -webkit-transform: translate(0, -100px); + transform: translate(0, -100px); + } +} +.ld.ld-slot-px { + -webkit-animation: ld-slot-px 6s infinite linear; + animation: ld-slot-px 6s infinite linear; +} diff --git a/gradio-0.9.9.5/gradio/static/css/style.css b/gradio-0.9.9.5/gradio/static/css/style.css new file mode 100644 index 0000000000..d1719d3518 --- /dev/null +++ b/gradio-0.9.9.5/gradio/static/css/style.css @@ -0,0 +1,114 @@ +body { + font-family: 'Open Sans', sans-serif; + margin: 0; +} +button, input[type="submit"], input[type="reset"], input[type="text"], input[type="button"], select[type="submit"] { + background: none; + color: inherit; + border: none; + padding: 0; + font: inherit; + cursor: pointer; + outline: inherit; + -webkit-appearance: none; + border-radius: 0; +} + +.loading_time { + font-size: large; + color: #EEA45D; + text-align: right; + padding-top: 5px; +} + +nav { + text-align: center; + padding: 16px 0 4px; +} +nav img { + margin-right: auto; + height: 32px; +} +#share { + text-align: center; + margin-bottom: 10px; + font-size: 14px; +} +#share-copy { + background-color: whitesmoke; + padding: 4px; + border-radius: 2px; +} +#title { + text-align: center; +} +.container { + max-width: 1028px; + width: 100%; + margin: 0 auto; +} +.panels { + display: flex; + flex-flow: row; + flex-wrap: wrap; + justify-content: center; +} +button.primary { + color: white; + background-color: #EEA45D; +} +button.secondary { + color: black; + background-color: #F6F6F6; +} +#featured_history { + margin: 4px 30px; +} +#featured_table { + border-collapse: collapse; + border: solid 2px whitesmoke; + margin-bottom: 20px; + table-layout: fixed; +} +#featured_table div { + display: inline-block; + padding: 10px; + text-align: center; + cursor: pointer; + max-width: 200px; + max-height: 100px; + overflow-y: auto; +} +#featured_table div:nth-child(even) { + background-color: whitesmoke; +} +#featured_table div:hover { + background-color: #EEA45D; +} +#featured_history img { + height: 60px; +} +#examples table { + border-collapse: collapse; + font-family: monospace; + padding: 8px; + background-color: whitesmoke; + border-right: solid 4px whitesmoke; + border-left: solid 4px whitesmoke; +} +#examples th { + padding: 8px; + text-align: left; + font-size: 18px; +} +#examples td { + padding: 8px; + cursor: pointer; +} + +#examples tbody tr:nth-child(odd) { + background-color: white; +} +#examples tbody tr:hover { + background-color: lightgray; +} \ No newline at end of file diff --git a/gradio-0.9.9.5/gradio/strings.py b/gradio-0.9.9.5/gradio/strings.py new file mode 100644 index 0000000000..2818b1e763 --- /dev/null +++ b/gradio-0.9.9.5/gradio/strings.py @@ -0,0 +1,10 @@ +en = { + "BETA_MESSAGE": "NOTE: Gradio is in beta stage, please report all bugs to: gradio.app@gmail.com", + "RUNNING_LOCALLY": "Running locally at: {}", + "NGROK_NO_INTERNET": "Unable to create public link for interface, please check internet connection or try " + "restarting python interpreter.", + "COLAB_NO_LOCAL": "Cannot display local interface on google colab, public link created.", + "PUBLIC_SHARE_TRUE": "To create a public link, set `share=True` in the argument to `launch()`.", + "MODEL_PUBLICLY_AVAILABLE_URL": "Model available publicly at: {} (may take up to a minute for link to be usable)", + "GENERATING_PUBLIC_LINK": "Generating public link (may take a few seconds...):", +} diff --git a/gradio-0.9.9.5/gradio/tunneling.py b/gradio-0.9.9.5/gradio/tunneling.py new file mode 100644 index 0000000000..45122c484a --- /dev/null +++ b/gradio-0.9.9.5/gradio/tunneling.py @@ -0,0 +1,107 @@ +""" +This file provides remote port forwarding functionality using paramiko package, +Inspired by: https://github.com/paramiko/paramiko/blob/master/demos/rforward.py +""" + +import select +import socket +import sys +import threading +from io import StringIO +import warnings +import paramiko + +DEBUG_MODE = False + + +def handler(chan, host, port): + sock = socket.socket() + try: + sock.connect((host, port)) + except Exception as e: + verbose("Forwarding request to {}:{} failed: {}".format(host, port, e)) + return + + verbose( + "Connected! Tunnel open {} -> {} -> {}".format(chan.origin_addr, + chan.getpeername(), + (host, port)) + ) + while True: + r, w, x = select.select([sock, chan], [], []) + if sock in r: + data = sock.recv(1024) + if len(data) == 0: + break + chan.send(data) + if chan in r: + data = chan.recv(1024) + if len(data) == 0: + break + sock.send(data) + chan.close() + sock.close() + verbose("Tunnel closed from {}".format(chan.origin_addr,)) + + +def reverse_forward_tunnel(server_port, remote_host, remote_port, transport): + transport.request_port_forward("", server_port) + while True: + chan = transport.accept(1000) + if chan is None: + continue + thr = threading.Thread(target=handler, args=(chan, remote_host, remote_port)) + thr.setDaemon(True) + thr.start() + + +def verbose(s): + if DEBUG_MODE: + print(s) + + +def create_tunnel(payload, local_server, local_server_port): + client = paramiko.SSHClient() + # client.set_missing_host_key_policy(paramiko.AutoAddPolicy()) + client.set_missing_host_key_policy(paramiko.WarningPolicy()) + + verbose( + "Connecting to ssh host {}:{} ...".format(payload["host"], int(payload[ + "port"])) + ) + try: + with warnings.catch_warnings(): + warnings.simplefilter("ignore") + client.connect( + hostname=payload["host"], + port=int(payload["port"]), + username=payload["user"], + pkey=paramiko.RSAKey.from_private_key(StringIO(payload["key"])), + ) + except Exception as e: + print( + "*** Failed to connect to {}:{}: {}}".format(payload["host"], + int(payload["port"]), e) + ) + sys.exit(1) + + verbose( + "Now forwarding remote port {} to {}:{} ...".format(int(payload[ + "remote_port"]), + local_server, + local_server_port) + ) + + thread = threading.Thread( + target=reverse_forward_tunnel, + args=( + int(payload["remote_port"]), + local_server, + local_server_port, + client.get_transport(), + ), + daemon=True, + ) + thread.start() + + return payload["share_url"] diff --git a/gradio-0.9.9.5/gradio/validation_data.py b/gradio-0.9.9.5/gradio/validation_data.py new file mode 100644 index 0000000000..14a4721d01 --- /dev/null +++ b/gradio-0.9.9.5/gradio/validation_data.py @@ -0,0 +1,16 @@ +ENGLISH_TEXTS = [ + "hello", + "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vestibulum est tellus, euismod eu sollicitudin sed, rutrum eget eros. Cras elementum quam sed orci luctus, id commodo quam varius. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Quisque vitae mi tortor. Pellentesque porttitor pretium elit. Donec faucibus tellus enim, eget auctor quam commodo sed. Etiam commodo neque dui, sit amet dictum mauris molestie non.", + "Two wrongs don't make a right", + "Call ME ISHMAEL!!!!!!!!!!!", + "Test text test text", +] + +BASE64_COLOR_IMAGES = [ + "", + "", + "", + "", + "", + "", +] \ No newline at end of file diff --git a/gradio-0.9.9.5/setup.py b/gradio-0.9.9.5/setup.py new file mode 100644 index 0000000000..42b32e26f1 --- /dev/null +++ b/gradio-0.9.9.5/setup.py @@ -0,0 +1,25 @@ +try: + from setuptools import setup +except ImportError: + from distutils.core import setup + +setup( + name='gradio', + version='0.9.9.5', + include_package_data=True, + description='Python library for easily interacting with trained machine learning models', + author='Abubakar Abid', + author_email='a12d@stanford.edu', + url='https://github.com/gradio-app/gradio-UI', + packages=['gradio'], + keywords=['machine learning', 'visualization', 'reproducibility'], + install_requires=[ + 'numpy', + 'requests', + 'paramiko', + 'scipy', + 'IPython', + 'scikit-image', + 'analytics-python', + ], +) diff --git a/gradio.egg-info/PKG-INFO b/gradio.egg-info/PKG-INFO index e2ad3441c9..40b581b42b 100644 --- a/gradio.egg-info/PKG-INFO +++ b/gradio.egg-info/PKG-INFO @@ -1,6 +1,6 @@ Metadata-Version: 1.0 Name: gradio -Version: 0.9.9.1 +Version: 0.9.9.6 Summary: Python library for easily interacting with trained machine learning models Home-page: https://github.com/gradio-app/gradio-UI Author: Abubakar Abid diff --git a/gradio.egg-info/SOURCES.txt b/gradio.egg-info/SOURCES.txt index 4183f362f2..c9bca4f9c4 100644 --- a/gradio.egg-info/SOURCES.txt +++ b/gradio.egg-info/SOURCES.txt @@ -50,6 +50,7 @@ gradio/static/img/vendor/icon-b.svg gradio/static/img/vendor/icon-c.svg gradio/static/img/vendor/icon-d.svg gradio/static/js/all_io.js +gradio/static/js/all_io.js.bak gradio/static/js/gradio.js gradio/static/js/utils.js gradio/static/js/interfaces/input/checkbox.js diff --git a/gradio.egg-info/requires.txt b/gradio.egg-info/requires.txt index f9d89d1594..6bb220b721 100644 --- a/gradio.egg-info/requires.txt +++ b/gradio.egg-info/requires.txt @@ -4,4 +4,4 @@ paramiko scipy IPython scikit-image -analytics +analytics-python diff --git a/gradio/inputs.py b/gradio/inputs.py index dd30433cbc..cfd1c51e3f 100644 --- a/gradio/inputs.py +++ b/gradio/inputs.py @@ -40,12 +40,6 @@ class AbstractInput(ABC): """ return {"label": self.label} - def sample_inputs(self): - """ - An interface can optionally implement a method that sends a list of sample inputs for inference. - """ - return [] - def preprocess(self, inp): """ By default, no pre-processing is applied to text. @@ -67,17 +61,12 @@ class AbstractInput(ABC): class Sketchpad(AbstractInput): - def __init__(self, cast_to="numpy", shape=(28, 28), invert_colors=True, - flatten=False, scale=1/255, shift=0, - dtype='float64', sample_inputs=None, label=None): + def __init__(self, shape=(28, 28), invert_colors=True, + flatten=False, label=None): self.image_width = shape[0] self.image_height = shape[1] self.invert_colors = invert_colors self.flatten = flatten - self.scale = scale - self.shift = shift - self.dtype = dtype - self.sample_inputs = sample_inputs super().__init__(label) @classmethod @@ -101,8 +90,6 @@ class Sketchpad(AbstractInput): array = np.array(im).flatten().reshape(1, self.image_width * self.image_height) else: array = np.array(im).flatten().reshape(1, self.image_width, self.image_height) - array = array * self.scale + self.shift - array = array.astype(self.dtype) return array def process_example(self, example): @@ -136,8 +123,7 @@ class Webcam(AbstractInput): class Textbox(AbstractInput): - def __init__(self, sample_inputs=None, lines=1, placeholder=None, default=None, label=None, numeric=False): - self.sample_inputs = sample_inputs + def __init__(self, lines=1, placeholder=None, default=None, numeric=False, label=None): self.lines = lines self.placeholder = placeholder self.default = default @@ -227,7 +213,7 @@ class Slider(AbstractInput): @classmethod def get_shortcut_implementations(cls): return { - "checkbox": {}, + "slider": {}, } @@ -283,6 +269,8 @@ class Image(AbstractInput): class Microphone(AbstractInput): + def __init__(self, label=None): + super().__init__(label) def preprocess(self, inp): """ diff --git a/gradio/interface.py b/gradio/interface.py index acb7b1a249..2bf81d1b2b 100644 --- a/gradio/interface.py +++ b/gradio/interface.py @@ -281,7 +281,6 @@ class Interface: from_ipynb = get_ipython() if "google.colab" in str(from_ipynb): is_colab = True - print("Google colab notebook detected.") except NameError: data = {'error': 'NameError in launch method'} try: @@ -307,10 +306,10 @@ class Interface: print(strings.en["RUNNING_LOCALLY"].format(path_to_local_server)) else: if debug: - print("This cell will run indefinitely so that you can see errors and logs. To turn off, " - "set debug=False in launch().") + print("Colab notebook detected. This cell will run indefinitely so that you can see errors and logs. " + "To turn off, set debug=False in launch().") else: - print("To show errors in colab notebook, set debug=True in launch()") + print("Colab notebook detected. To show errors in colab notebook, set debug=True in launch()") if share: try: @@ -331,6 +330,7 @@ class Interface: is_colab ): # For a colab notebook, create a public link even if share is False. share_url = networking.setup_tunnel(server_port) + print("Running on External URL:", share_url) if self.verbose: print(strings.en["COLAB_NO_LOCAL"]) else: # If it's not a colab notebook and share=False, print a message telling them about the share option. diff --git a/gradio/outputs.py b/gradio/outputs.py index f34c7d2981..3c2e5e633c 100644 --- a/gradio/outputs.py +++ b/gradio/outputs.py @@ -10,6 +10,7 @@ import json from gradio import preprocessing_utils import datetime import operator +from numbers import Number # Where to find the static resources associated with each template. BASE_OUTPUT_INTERFACE_JS_PATH = 'static/js/interfaces/output/{}.js' @@ -53,8 +54,8 @@ class Label(AbstractOutput): super().__init__(label) def postprocess(self, prediction): - if isinstance(prediction, str): - return {"label": prediction} + if isinstance(prediction, str) or isinstance(prediction, Number): + return {"label": str(prediction)} elif isinstance(prediction, dict): sorted_pred = sorted( prediction.items(), @@ -104,15 +105,11 @@ class KeyValues(AbstractOutput): class Textbox(AbstractOutput): - def __init__(self, lines=1, placeholder=None, label=None): - self.lines = lines - self.placeholder = placeholder + def __init__(self, label=None): super().__init__(label) def get_template_context(self): return { - "lines": self.lines, - "placeholder": self.placeholder, **super().get_template_context() } @@ -121,7 +118,6 @@ class Textbox(AbstractOutput): return { "text": {}, "number": {}, - "textbox": {"lines": 7} } def postprocess(self, prediction): @@ -133,7 +129,7 @@ class Textbox(AbstractOutput): class Image(AbstractOutput): - def __init__(self, label=None, plot=False): + def __init__(self, plot=False, label=None): self.plot = plot super().__init__(label) diff --git a/gradio/static/css/gradio.css b/gradio/static/css/gradio.css index f5f39cb8a8..95d4de6511 100644 --- a/gradio/static/css/gradio.css +++ b/gradio/static/css/gradio.css @@ -31,10 +31,18 @@ display: flex; flex-flow: column; } +.output_panel { + position: relative; +} .loading { + position: absolute; + top: 10px; + left: 10px; margin-left: auto; + z-index: 1; } .loading img { + width: 50px; display: none; } .panel_buttons { diff --git a/gradio/static/css/interfaces/output/textbox.css b/gradio/static/css/interfaces/output/textbox.css index 95b2440800..2dc62e3db2 100644 --- a/gradio/static/css/interfaces/output/textbox.css +++ b/gradio/static/css/interfaces/output/textbox.css @@ -1,5 +1,4 @@ .output_text { - resize: none; width: 100%; font-size: 18px; outline: none; @@ -8,4 +7,9 @@ border: solid 1px black; box-sizing: border-box; padding: 4px; + min-height: 30px; + font-family: monospace; + white-space: pre-wrap; /* CSS3 */ + white-space: -moz-pre-wrap; /* Firefox */ + word-wrap: break-word; /* IE */ } diff --git a/gradio/static/img/logo_error.png b/gradio/static/img/logo_error.png index 6629a6d514..7b22195776 100644 Binary files a/gradio/static/img/logo_error.png and b/gradio/static/img/logo_error.png differ diff --git a/gradio/static/js/all_io.js b/gradio/static/js/all_io.js index 183450f4a5..7a7ca9eae7 100644 --- a/gradio/static/js/all_io.js +++ b/gradio/static/js/all_io.js @@ -22,8 +22,7 @@ var io_master_template = { this.target.find(".loading").removeClass("invisible"); this.target.find(".loading_in_progress").show(); this.target.find(".loading_failed").hide(); - this.target.find(".output_interface").addClass("invisible"); - this.target.find(".output_interfaces .panel_header").addClass("invisible"); + this.target.find(".output_interfaces").css("opacity", 0.5); } this.fn(this.last_input).then((output) => { io.output(output); @@ -47,11 +46,14 @@ var io_master_template = { } if (this.config.live) { - this.gather(); + var io = this; + var refresh_lag = this.config.refresh_lag || 0; + window.setTimeout(function() { + io.gather(); + }, refresh_lag); } else { this.target.find(".loading").addClass("invisible"); - this.target.find(".output_interface").removeClass("invisible"); - this.target.find(".output_interfaces .panel_header").removeClass("invisible"); + this.target.find(".output_interfaces").css("opacity", 1); } }, flag: function(message) { diff --git a/gradio/static/js/gradio.js b/gradio/static/js/gradio.js index ab5343535d..f6660c09b2 100644 --- a/gradio/static/js/gradio.js +++ b/gradio/static/js/gradio.js @@ -11,7 +11,7 @@ function gradio(config, fn, target) {