/*!/wp-content/plugins/TooltipProPlus/assets/css/jquery.listnav.css*/
#glossary-categories {
	width: auto;
}

.listNav {
	margin: 0 0 5px;
	position: relative;
}

.cm-glossary .listNav .ln-letters {
	margin: 20px 0 10px;
	overflow: visible;
}

.cm-glossary .glossary_itemdesc {
	display: block;
	font-style: initial;
}

.cm-glossary .listNav .ln-letters:after,
.ln-letters:after {
	content: "";
	display: table;
	clear: both;
}

.glossary .ln-letters {
	margin-bottom: 10px;
}

.ln-letters a {
	font-size: 7pt;
	display: block;
	float: left;
	padding: 2px 6px;
	border: 1px solid silver;
	text-decoration: none;
	margin-left: -1px;
	box-shadow: none;
}

.ln-letters a:hover {
	margin-top: -10px;
	padding-top: 12px;
}

.ln-letters a:first-child,
.ln-letters a.ln-first,
.ln-letters a.ln-after-newline {
	margin-left: 0;
}

.ln-letters a.ln-disabled + a.ln-first {
	margin-left: -1px;
}

.ln-letters.round a {
	border-radius: 50%;
	width: 3em;
	height: 3em;
	text-align: center;
	margin: 3px !important;
}

.ln-letters.round a:hover {
	margin-top: 0;
	padding-top: 2px;
	padding-bottom: 2px;
}

.ln-letters.round + .ln-letter-count,
.ln-letters.round .ln-letter-count {
	background-color: transparent;
	text-align: center;
}

.small .ln-letters a {
	font-size: 7pt;
	line-height: 2.5em;
}

.medium .ln-letters a {
	font-size: 10pt;
	line-height: 2em;
}

.large .ln-letters a {
	font-size: 14pt;
	line-height: 1.75em;
}

.medium .ln-letters.round a {
	line-height: 2.8em;
}

.large .ln-letters.round a {
	line-height: 2.8em;
}

.ln-letters a.ln-last {
	border-right: 1px solid silver;
}

.ln-letters a:hover,
.ln-letters a.ln-selected {
	background-color: #eaeaea;
}

.ln-letters a.ln-disabled {
	color: #ccc;
}

#glossaryList-nav .ln-letters a.ln-disabled.ln-newline {
	clear: both;
	display: block;
	width: 0;
	border: 0;
	padding: 0;
	margin: 0;
	height: 0;
}

#glossaryList-nav:after {
	content: '';
	display: table;
	clear: both;
}

.ln-letter-count {
	text-align: center;
	font-size: 0.7em;
	line-height: 1;
	margin-bottom: 3px;
	color: #000;
	background-color: #eaeaea;
	pointer-events: none;
	border: none;
	box-sizing: border-box;
	border-bottom: none;
}

.small .ln-letter-count,
.glossary-container.no-counts .small .ln-letters a {
	font-size: 7pt;
}

.medium .ln-letter-count {
	font-size: 8pt;
}

.large .ln-letter-count {
	font-size: 9pt;
}

.glossary-container.no-counts .ln-letters a:hover {
	margin-top: 0;
	padding-top: 2px;
}

.glossary-container.no-counts .cm-glossary .listNav .ln-letters {
	margin: 0;
	overflow: hidden;
}

.glossary-container.no-counts .small .ln-letters a {
	font-size: 7pt;
	line-height: 1.25em;
}

.glossary-container.no-counts .medium .ln-letters a {
	font-size: 10pt;
	line-height: 1.25em;
}

.glossary-container.no-counts .large .ln-letters a {
	font-size: 14pt;
	line-height: 1.25em;
}

.glossary-container.no-counts .ln-letter-count {
	text-align: center;
	font-size: 0.7em;
	line-height: 1;
	margin-bottom: 3px;
	color: #000;
	background-color: #eaeaea;
	pointer-events: none;
	border: none;
	box-sizing: border-box;
	border-bottom: none;
}

.glossary-container.no-counts .small .ln-letters a,
.glossary-container.no-counts .medium .ln-letters a,
.glossary-container.no-counts .large .ln-letters a {
	line-height: 1.25em;
}

.glossary-container.no-counts .medium .ln-letters a {
	font-size: 10pt;
}

.glossary-container.no-counts .large .ln-letters a {
	font-size: 14pt;
}

.glossary-container .glossaryList li .glossary_itemdesc {
	margin: 0 0 20px 0;
	display: block;
}

/* Styles for Tiles*/
.tiles {
	max-width: 100%;
	clear: both;
	overflow: hidden;
}

.tiles ul.glossaryList {
	list-style-type: none;
	margin: 0;
}

.tiles ul.glossaryList li {
	float: left;
}

.tiles ul.glossaryList a {
	display: block;
	text-align: center;
	min-width: 85px;
	width: 85px;
	word-wrap: break-word;
	border: 1px solid silver;
	padding: 10px;
	margin: 0 10px 10px 0;
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.tiles ul.glossaryList li:hover {
	cursor: pointer;
	background-color: #eee;
	z-index: 0;
	white-space: normal;
	width: auto;
}

.tiles ul.glossaryList li .glossary_itemdesc {
	margin-bottom: 0;
}

.tiles ul.glossaryList span {
	display: block;
	text-align: center;
	min-width: 85px;
	width: 85px;
	word-wrap: break-word;
	border: 1px solid silver;
	padding: 10px;
	margin: 0 10px 10px 0;
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.tiles ul.glossaryList span:hover {
	background-color: #eee;
	z-index: 0;
	white-space: normal;
	width: auto;
}
/* Styles for Big Tiles */
.cm-glossary.tiles.big ul.glossaryList a {
	display: block;
	text-align: center;
	min-width: 179px;
	width: 179px;
	word-wrap: break-word;
	border: 1px solid silver;
	padding: 10px;
	margin: 0 10px 10px 0;
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.cm-glossary.tiles.big ul.glossaryList span {
	display: block;
	text-align: center;
	min-width: 179px;
	width: 179px;
	word-wrap: break-word;
	border: 1px solid silver;
	padding: 10px;
	margin: 0 10px 10px 0;
	text-decoration: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Styles for Classic Table */
.cm-glossary.table.classic ul.glossaryList li {
	float: left;
	width: 200px;
	list-style: none;
	margin: 0 20px 0 75px;
	display: inline;
}

.cm-glossary.table.classic ul.glossaryList li.the-index-letter {
	float: left;
	width: 21px;
	margin: 0 -20px 0 0;
	font-size: 36px;
	line-height: 1.5em;
	text-transform: uppercase;
	padding: 0;
	border: 0;
}

.cm-glossary.table.classic ul.glossaryList li.the-letter-separator {
	clear: both;
	height: 10px;
	width: 100%;
	border-top: 1px solid #eaeaea;
	margin: 10px 1px 0 0;
	border-bottom: none;
}

.cm-glossary.table ul.glossaryList li.the-index-letter > * {
	margin: 0;
	padding: 0;
}

/* Sidebar + term page */
.cm-glossary.sidebar-termpage {
	position: relative;
}

.cm-glossary.sidebar-termpage > div {
	display: inline-block;
	vertical-align: top;
}

.cm-glossary.sidebar-termpage .glossary-container {
	width: 35%;
}

.cm-glossary.sidebar-termpage .glossary-container:before,
.cm-glossary.sidebar-termpage .glossary-container:after {
	display: table;
	content: " ";
	clear: both;
}

.cm-glossary.sidebar-termpage #glossary-categories {
	float: none;
	margin: 10px 0;
}

.cm-glossary.sidebar-termpage .glossary-term-content {
	width: 65%;
	overflow: hidden;
}

.cm-glossary.sidebar-termpage .glossary-term-content .glossary_term_title {
	font-size: 24pt;
	margin-bottom: 1em;
}

.cm-glossary.sidebar-termpage .glossary-term-content > div.glossary_term_description {
	width: 60%;
	overflow: hidden;
}

/* Pagination */
.cm-glossary .glossary-container ul.pageNumbers {
	font-size: 12px;
	clear: both;
	padding: 20px 0;
}

.cm-glossary .glossary-container ul.pageNumbers li {
	cursor: pointer;
	display: inline-block;
	border: solid 1px silver;
	border-right: none;
	padding: 3px 5px;
	list-style-type: none;
	margin: 0;
	line-height: 1;
	background-color: #fff;
}

.cm-glossary .glossary-container ul.pageNumbers li.selected,
.cm-glossary .glossary-container ul.pageNumbers li:hover {
	background-color: rgba(204, 204, 204, 0.7);
}

.cm-glossary .glossary-container ul.pageNumbers li + li {
	border-right: solid 1px silver;
	display: inline-block;
}

.cm-glossary .glossary-container ul.pageNumbers li a {
	text-decoration: none;
	border: none;
	padding: 0;
	margin: 0;
}

.cm-glossary .glossary-container ul.pageNumbers li.disabled {
	background-color: rgba(204, 204, 204, 0.7);
	cursor: not-allowed;
	color: rgb(245, 245, 245);
}

.cm-glossary .glossary-container ul.pageNumbers.round li.numeric,
.cm-glossary .glossary-container ul.pageNumbers.round li.prev-section,
.cm-glossary .glossary-container ul.pageNumbers.round li.next-section {
	border-radius: 50%;
	height: 3em;
	width: 3em;
	text-align: center;
	line-height: 2em;
}

.cm-glossary .glossary-container ul.pageNumbers.round li.prev,
.cm-glossary .glossary-container ul.pageNumbers.round li.next {
	border: none;
}

.cm-glossary .glossary-container ul.pageNumbers.round li.numeric a {
	text-align: center;
	display: block;
}

/* Styles for AMP version of the plugin  */
form.amp-form-submit-success ul.glossaryList,
form.amp-form-submit-success div[id^="rendered-message-amp-form"] .glossary_top_filter,
form.amp-form-submit-success div[id^="rendered-message-amp-form"] #glossaryList-nav,
form.amp-form-submitting ul.glossaryList,
form.amp-form-submitting div[id^="rendered-message-amp-form"] .glossary_top_filter,
form.amp-form-submitting div[id^="rendered-message-amp-form"] #glossaryList-nav {
	display: none;
}

form.amp-form-submit-success div[id^="rendered-message-amp-form"] ul.glossaryList {
	display: block;
}

.cmtt-social-box > amp-social-share {
	vertical-align: middle;
}

.glossary-container span.glossaryLink {
	cursor: pointer;
}

.ln-serv-letter {
	position: relative;
}

.ln-serv-letter .ln-letter-count-amp {
	display: none;
	position: absolute;
	top: -5px;
	left: 0;
	width: 100%;
	text-align: center;
}

.ln-serv-letter:hover .ln-letter-count-amp {
	display: inline-block;
}

div.glossary-container #cmttForm > p br,
div.glossary-container #cmttForm br {
	display: none !important;
}
/* ML Expand style */
.cm-glossary.expand ul.glossaryList li.the-index-letter {
	text-align: center;
	line-height: 1.5em;
	text-transform: uppercase;
	clear: both;
	width: 100%;
	padding: 5px 0;
	border: none;
	margin-top: 35px;
}

.cm-glossary.expand ul.glossaryList li.the-index-letter > div {
	font-size: 40px;
	line-height: 1.2;
	font-weight: normal;
	font-family: "ScalaSansWeb", Arial, sans-serif;
	margin-bottom: 0;
}

.cm-glossary.expand ul.glossaryList li > a.glossaryLink {
	font-size: 18px;
	font-weight: bold;
	font-family: "ScalaSansWeb", Arial, sans-serif;
}

.cm-glossary.expand a.glossaryLink {
	border-bottom: none !important;
	box-shadow: none !important;
}

.cm-glossary.expand ul.glossaryList li > .glossary_itemdesc {
	font-size: 14px;
	text-align: justify;
	font-family: "ScalaSansWeb", Arial, sans-serif;
}

.expand-back-to-top {
	border-bottom-style: solid;
	border-bottom-width: 1px;
	text-align: right;
	font-size: 16px;
	padding: 5px 0 2px 0;
	font-family: "ScalaSansWeb", Arial, sans-serif;
}

.expand-space {
	margin: 20px;
}

/* MD Expand2 style */
.cm-glossary.expand2 ul.glossaryList li {
	/*max-width: 50%;*/
	width: 100%;
	display: inline-block;
	padding: 10px;
	vertical-align: top;
}

.cm-glossary.expand2 ul.glossaryList li.the-index-letter {
	text-align: center;
	line-height: 1.5em;
	text-transform: uppercase;
	clear: both;
	width: 100%;
	padding: 5px 0;
	border: none;
	max-width: 100%;
}

.cm-glossary.expand2 ul.glossaryList li.the-index-letter > div {
	font-size: 40px;
	line-height: 1.2;
	font-weight: normal;
	font-family: "ScalaSansWeb", Arial, sans-serif;
	margin-bottom: 0;
}

.cm-glossary.expand2 ul.glossaryList li.the-index-letter {
	max-width: 100%;
}

.cm-glossary.expand2 ul.glossaryList li.the-letter-separator {
	display: none !important;
}

/* ML Grid style */
.cm-glossary.grid ul.glossaryList li.the-index-letter {
	text-transform: uppercase;
	margin-top: 30px;
	margin-bottom: 10px;
	clear: both;
	width: 100%;
}

.cm-glossary.grid ul.glossaryList li.the-index-letter > div {
	font-size: 1.0625rem;
	line-height: 1.2;
	margin: 0;
	font-weight: bold;
}

.cm-glossary.grid ul.glossaryList li > a.glossaryLink {
	box-shadow: none;
	font-size: 1rem;
	border-bottom: none !important;
}

.cm-glossary.grid ul.glossaryList li {
	float: left;
	width: 200px;
	list-style: none;
	margin: 0 20px 0 50px;
	display: inline;
}

/* ML Cube style */
.cm-glossary.cube .listNav .ln-letters {
	padding: 0 0 0 0;
	list-style: none;
	width: 25%;
	float: left;
	margin: 20px;
}

.cm-glossary.cube .listNav .ln-letters a {
	cursor: pointer;
	color: black;
	border: 1px solid black;
	border-radius: 3px !important;
	text-align: center !important;
	width: 30px;
	height: 30px;
	font-weight: bold;
	font-family: "Montserrat", helvetica, arial, "lucida grande", sans-serif;
	line-height: 30px;
	font-size: 20px;
	margin: 5px;
	padding: 0;
}

.cm-glossary.cube .listNav .ln-letters a:hover {
	background-color: transparent;
	padding: 0;
}

.cm-glossary.cube .listNav .ln-letters .ln-all {
	display: none;
}

.cm-glossary.cube .listNav .ln-letters .ln-_ {
	display: none;
}

.cm-glossary.cube .listNav .ln-letters a.ln-disabled {
	border: 1px solid lightgrey;
	color: lightgrey;
	cursor: default;
}

.cm-glossary.cube ul.glossaryList li.the-index-letter {
	text-transform: uppercase;
	clear: both;
	width: 100%;
	margin-top: 20px;
}

.cm-glossary.cube div#glossaryList-nav .ln-letter-count {
	display: none !important;
}

.cm-glossary.cube ul.glossaryList {
	float: left;
	width: 30%;
	margin-top: 20px !important;
}

.cm-glossary.cube #glossaryList-nav:after {
	clear: none;
}

/* ML image tiles style */
.cm-glossary.image-tiles ul#glossaryList li {
	position: relative;
	padding: 0px 5px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	float: left;
	width: 33.33333%;
	margin-bottom: 35px;
}

@media screen and (max-width: 768px) {
	.cm-glossary.image-tiles ul#glossaryList li {
		width: 50%;
	}
}

@media screen and (max-width: 451px) {
	.cm-glossary.image-tiles ul#glossaryList li {
		width: 100%;
	}
}

.cm-glossary.image-tiles ul#glossaryList {
	margin: 0 -5px;
}

.cm-glossary.image-tiles ul#glossaryList:after {
	content: '';
	display: block;
	height: 0;
	width: 0;
	opacity: 0;
	overflow: hidden;
	clear: both;
}

.cm-glossary.image-tiles ul#glossaryList li {
	padding: 0 5px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

.cm-glossary.image-tiles ul#glossaryList li.cmtt-has-thumbnail {
	margin-left: 0;
}

.cm-glossary.image-tiles ul#glossaryList li:nth-of-type(3n+4) {
	clear: unset;
}

.cm-glossary.image-tiles ul#glossaryList li.cmtt-has-thumbnail img {
	display: block;
	width: 100%;
	margin-bottom: 5px;
}

.cm-glossary.image-tiles a.cmtt-thumbnail {
	display: inline-block;
}

.cm-glossary.image-tiles ul#glossaryList li:before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(255, 255, 255, 0.2);
	pointer-events: none;
}

.cm-glossary.image-tiles .glossaryLink,
.cm-glossary.image-tiles .glossaryLinkMain {
	position: absolute;
	bottom: 5px;
	left: 5px;
	display: block;
	right: 5px;
	-webkit-background: linear-gradient(to top, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
	-moz-background: linear-gradient(to top, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
	background: linear-gradient(to top, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
	padding: 5px 5px;
}

.cm-glossary.image-tiles .glossaryLink,
.cm-glossary.image-tiles .glossaryLinkMain,
.cm-glossary.image-tiles ul#glossaryList li:before {
	-webkit-transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	transition: all 0.2s ease;

}

/* Classic excerpt + definition */
.cm-glossary.classic-definition ul > li,
.cm-glossary.classic-excerpt ul > li {
	margin-left: 0;
	margin-bottom: 15px;
}

.cm-glossary.classic-definition #glossaryList-nav,
.cm-glossary.term-definition #glossaryList-nav,
.cm-glossary.img-term-definition #glossaryList-nav {
	margin-bottom: 15px;
}

#cmtt-pagination-container .pageNumbers li:not(:last-child) {
	border-right: none;
}

/* Term + definition  AND Img + Term + Definition */
.cm-glossary.term-definition ul > li,
.cm-glossary.img-term-definition ul > li {
	margin: 0 0 15px 0;
	display: grid;
	grid-template-columns: 1fr 3fr;
	border-top: 1px solid rgb(192, 192, 192);
}

.cm-glossary.term-definition ul > li:first-child {
	border: none;
}

.cm-glossary.term-definition ul > li > div,
.cm-glossary.img-term-definition ul > li > div {
	padding: 0.75em;
}

.cm-glossary.img-term-definition ul > li > div > img,
.cm-glossary.img-term-definition ul > li > div > a > img {
	width: 100%;
	height: auto;
}

.cm-glossary.img-term-definition ul > li,
.cm-glossary.term-carousel .slick-slide,
.cm-glossary.tiles-with-definition ul > li {
	-webkit-box-shadow: -1px 0 8px -4px rgba(56, 56, 56, 1);
	-moz-box-shadow: -1px 0 8px -4px rgba(56, 56, 56, 1);
	box-shadow: -1px 0 8px -4px rgba(56, 56, 56, 1);
	border: none;
}

/* Terms carousel */
.cm-glossary.term-carousel .slick-slide,
.cm-glossary.tiles-with-definition ul > li {
	padding: 0.55em;
	height: 245px;
	margin: 10px 15px;
	overflow: hidden;
}

.cm-glossary.term-carousel .slick-slide .glossaryLink {
	display: inline-block;
	margin: 0 0 10px 0;
}

.cm-glossary.term-carousel .term-carousel-wrapper {
	position: relative;
}

.cm-glossary.term-carousel button.slick-prev,
.cm-glossary.term-carousel button.slick-next {
	position: absolute;
	z-index: 9999999;
	top: 50%;
	transform: translate(0, -50%);
	height: 40px;
	width: 40px;
	padding: 0;
	background-color: rgba(102, 102, 102, 0.7);
}

.cm-glossary.term-carousel button.slick-prev {
	left: -20px;
}

.cm-glossary.term-carousel button.slick-next {
	right: -20px;
}

.cm-glossary.term-carousel button.slick-next:hover,
.cm-glossary.term-carousel button.slick-prev:hover {
	background-color: rgba(102, 102, 102, 0.95);
}

.cm-glossary.term-carousel .progress-indicator {
	opacity: 0.97;
	display: block;
}

/* Tiles + definition */
.cm-glossary.tiles-with-definition ul {
	display: grid;
	grid-gap: 30px;
	grid-template-columns: repeat(auto-fill, 220px);
}

.cm-glossary.tiles-with-definition ul > li {
	margin: 0;
}

.cm-glossary.tiles-with-definition ul > li > .glossaryLink {
	display: inline-block;
	margin: 10px 0;
}

/* Related articles pagination*/
#cmtt-pagination-container .pageNumbers li:not(:last-child) {
	border-right: none;
}

/* Lightbox for the "Image + term + definition" view */
.cmtt-lightbox-wrapper {
	display: none;
	opacity: 0;
}

.cmtt-lightbox-wrapper.active {
	opacity: 1;
	background-color: rgba(0, 0, 0, 0.75);
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: -ms-flexbox;
	display: -webkit-box;
	display: flex;
	-ms-flex-flow: column wrap;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	flex-flow: column wrap;
	-ms-flex-pack: center;
	-webkit-box-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	-webkit-box-align: center;
	align-items: center;
	z-index: 1000000;
}

.cmtt-lightbox-wrapper.active .cmtt-lightbox-content {
	padding: 20px;
	position: relative;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	cursor: auto;
	max-width: 85vw;
	max-height: 85vw;
	z-index: 10000002;
	text-align: center;
}

.cmtt-lightbox-wrapper.active .img-holder {
	max-height: 65vw;
	margin: 0 auto;
}

.cmtt-lightbox-wrapper.active .cmtt-lightbox-close {
	position: absolute;
	right: 20px;
	top: 20px;
	width: 22px;
	height: 22px;
	cursor: pointer;
}

.cmtt-lightbox-wrapper.active .cmtt-lightbox-close:before, .cmtt-lightbox-close:after {
	position: absolute;
	left: 10px;
	content: ' ';
	height: 22px;
	width: 2px;
	background-color: #ffffff;
}

.cmtt-lightbox-wrapper.active .cmtt-lightbox-close:before {
	transform: rotate(45deg);
}

.cmtt-lightbox-wrapper.active .cmtt-lightbox-close:after {
	transform: rotate(-45deg);
}

.cm-glossary.img-term-definition .cmtt-thumbnail {
	display: block;
	position: relative;
}

.cm-glossary.img-term-definition .cmtt-thumbnail[data-link="1"]:hover:before {
	content: url('/wp-content/plugins/TooltipProPlus/assets/css/images/search.svg');
	position: absolute;
	width: 20px;
	height: 20px;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	opacity: 1;
	margin: auto;
	text-align: center;
	transition: all 0.4s;
	-webkit-transition: all 0.4s;
	z-index: 200;
}

.cm-glossary.img-term-definition .cmtt-thumbnail[data-link="1"]:after {
	content: '';
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: rgba(0, 0, 0, 0.6);
	opacity: 0;
	transition: all 0.4s;
	-webkit-transition: all 0.4s;
}

.cm-glossary.img-term-definition .cmtt-thumbnail[data-link="1"]:hover:after {
	opacity: 1;
}

@media only screen and (max-width: 600px) {
	.cm-glossary.img-term-definition .glossary-container ul#glossaryList > li {
		display: block;
	}

	.cm-glossary.img-term-definition .cmtt-thumbnail:hover:before {
		content: '';
	}

	.cm-glossary.img-term-definition .cmtt-thumbnail:hover:after {
		opacity: 0;
	}
}

body.disable-scroll {
	overflow: hidden;
	height: 100%;
}

/* Accordion View style */

.cm-glossary.accordion-view .glossaryList li:not(.active-term) .glossary_itemdesc{
	display: none;
}

.cm-glossary.accordion-view .glossaryList li:not(.the-index-letter){
	border-bottom: 1px solid #cecfd0;
	line-height: 2.5em;
}

.cm-glossary.accordion-view .glossaryList li:not(.the-index-letter) .glossaryLinkMain ,
.cm-glossary.accordion-view .glossaryList li:not(.the-index-letter) .glossary-link-title{
	border-bottom: unset !important;
	width: 100%;
	display: block;
}

.cm-glossary.accordion-view .glossaryList li .glossaryLinkMain span.dashicons,
.cm-glossary.accordion-view .glossaryList li .glossary-link-title span.dashicons{
	vertical-align: text-top;
	margin-right: 10px;
}

.cm-glossary.accordion-view .the-index-letter > *{
	padding: 10px !important;
	text-transform: uppercase;
}

.cm-glossary.accordion-view .ln-letters, .cm-glossary.accordion-view-2 .ln-letters{
	text-align: center;
}

.cm-glossary.accordion-view .ln-letters a:not(.ln-last):after, .cm-glossary.accordion-view-2 .ln-letters a:not(.ln-last):after{
	content: '•';
	margin-left: 5px;
	color: #cecfd0;
}

.cm-glossary.accordion-view .ln-letters a, .cm-glossary.accordion-view-2 .ln-letters a{
	width: fit-content;
	border: none;
	font-weight: bold;
	display: inline-block;
	float: unset;
    text-decoration: none;
}

.cm-glossary.accordion-view .the-index-letter{
	border-radius: 5px;
	margin: 10px 0;
}

.cm-glossary.accordion-view  .glossaryList li{
    cursor: pointer;
}

/* Accordion View 2 style */

.cm-glossary.accordion-view-2 .glossaryList {
	list-style: none;
	padding: 0;
	margin: 0;
}

.cm-glossary.accordion-view-2 .glossaryList li {
	border-top: 1px solid #ccc;
    cursor: pointer;
}

.cm-glossary.accordion-view-2 .glossaryList:last-child{
	border-bottom: 1px solid #ccc;
}

.cm-glossary.accordion-view-2 .glossaryList .glossaryLinkMain,
.cm-glossary.accordion-view-2 .glossaryList .glossary-link-title{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px;
	cursor: pointer;
	text-decoration: none;
	color: #333;
	font-weight: bold;
	position: relative;
	border-bottom: unset !important;
}

.cm-glossary.accordion-view-2 .glossaryList .glossaryLinkMain::after,
.cm-glossary.accordion-view-2 .glossaryList .glossary-link-title::after {
	content: "\f347";
	transition: transform 0.3s ease;
	font-family:dashicons;
}

.cm-glossary.accordion-view-2 .glossaryList li.active .glossaryLinkMain::after,
.cm-glossary.accordion-view-2 .glossaryList li.active .glossary-link-title::after {
	transform: rotate(180deg);
}

.cm-glossary.accordion-view-2 .glossaryList li.active dfn, .cm-glossary.accordion-view .glossaryList li.active-term dfn {
	display: block !important;
}

.cm-glossary.accordion-view-2 .glossaryList dfn {
	display: none;
	padding: 12px;
}

.cm-glossary.accordion-view-2 .ln-letters a:not(.ln-last):after{
	margin-left: 3px;
}
.cm-glossary.accordion-view-2 .ln-letters a{
	padding: 0 2px;
}

.cm-glossary.accordion-view-2 .the-index-letter {
    text-transform: uppercase;
    border: none !important;
    margin: 10px 0;
}

/* Term flipboxes with definition */
.cm-glossary.flipboxes-with-definition .glossaryList {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	grid-gap: 10px;
}

.cm-glossary.flipboxes-with-definition .glossaryList > li {
	background-color: transparent;
	height: 160px;
	perspective: 1000px;
}

.cm-glossary.flipboxes-with-definition .glossaryList > li > div {
	position: relative;
	width: 100%;
	height: 100%;
	text-align: center;
	transition: transform 0.8s;
	transform-style: preserve-3d;
}

.cm-glossary.flipboxes-with-definition .glossaryList > li:hover > div {
	transform: rotateY(180deg);
}

.cm-glossary.flipboxes-with-definition .glossaryList > li > div.term-block > .glossaryLinkMain,
.cm-glossary.flipboxes-with-definition .glossaryList > li > div.term-block > .glossaryLink {
	display: flex;
	justify-content: center;
	height: 160px;
	background: #c1afff;
	border: unset;
	color: #ffffff;
	align-items: center;
	overflow-wrap: normal;
	overflow: hidden;
	padding: 10px;
}

.cm-glossary.flipboxes-with-definition .glossaryList > li > div.term-block > .glossaryLinkMain,
.cm-glossary.flipboxes-with-definition .glossaryList > li > div.term-block > .glossaryLink,
.cm-glossary.flipboxes-with-definition .glossaryList > li > div.term-block .glossary_itemdesc {
	position: absolute;
	width: 100%;
	height: 100%;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	-webkit-box-shadow: -1px 0 7px -4px rgba(56, 56, 56, 0.85);
	-moz-box-shadow: -1px 0 7px -4px rgba(56, 56, 56, 0.85);
	box-shadow: -1px 0 7px -4px rgba(56, 56, 56, 0.85);
}

.cm-glossary.flipboxes-with-definition .glossaryList > li > div.term-block > .glossary_itemdesc {
	display: grid;
	grid-template-rows: 1fr 50px;
	font-size: 12px;
	color: #000000;
	transform: rotateY(180deg);
	height: 160px;
	overflow: hidden;
	background-color: #ffffff;
	padding: 10px;
	cursor: pointer;
}

.cm-glossary.flipboxes-with-definition .glossaryList .glossary_itemdesc .glossary-read-more-link {
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #c1afff;
	color: #ffffff;
	text-transform: uppercase;
}

@media (max-width: 1024px) {
	.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList {
		grid-template-columns: repeat(5, 1fr);
	}
}

@media (max-width: 930px) {
	.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList {
		grid-template-columns: repeat(4, 1fr);
	}
}

@media (max-width: 768px) {
	.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 400px) {
	.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList {
		grid-template-columns: repeat(2, 1fr);
	}
}

.cm-showing-tags {
	margin: 15px 0 10px;
}

.cm-showing-tags .glossary-search-clear {
	margin: 0 0 0 5px;
	font-size: 10px;
	padding: 2px;
	line-height: 15px;
	/*background-color: rgba(64, 70, 77, 0.81);*/
	font-weight: bold;
	height: 15px;
	width: 15px;
	display: inline-block;
	color: #666;
	vertical-align: text-top;
	border-radius: 7.5px;
	text-align: center;
}

body.rtl .cmtt-tags-filter a.cmtt-glossary-tag {
	border-right: 1px solid;
	margin: 0 5px 0 0;
	padding: 0 5px 0 0;
}

@media screen and (max-width: 768px) {
	.cmtt-lightbox-wrapper.active .cmtt-lightbox-content {
		max-width: 95%;
		max-height: 95%;
		padding: 0;
	}

	.cmtt-lightbox-wrapper.active .img-holder {
		max-height: 85%;
	}

	.cmtt-lightbox-wrapper.active .cmtt-lightbox-content {
		max-width: 95%;
		max-height: 95%;
		padding: 0;
	}

	.cmtt-lightbox-wrapper.active .img-holder {
		max-height: 85%;
	}

	.cm-glossary ul.glossaryList li .glossary_itemdesc a {
		word-break: break-all;
	}
}

@media only screen and (max-width: 600px) {
	.cm-glossary.img-term-definition .glossary-container ul#glossaryList > li {
		display: block;
	}

	.cm-glossary.img-term-definition .cmtt-thumbnail:hover:before {
		content: '';
	}

	.cm-glossary.img-term-definition .cmtt-thumbnail:hover:after {
		opacity: 0;
	}
}

/* Styles for Accordion View */
.cm-glossary.accordion-view .ln-letters {
    border-radius: 6px;
    border: 1px solid #cecfd0;
}
/* Styles for Cards View */

.cm-glossary.cards-view .ln-letters {
    border: none;
    text-align: center;
}

.cm-glossary.cards-view .ln-letters .ln-disabled{
    opacity: 0.4;
    cursor: default;
}

.cm-glossary.cards-view .glossaryList {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 0;
    width: 100%;
    justify-content: flex-start;
}
.cm-glossary.cards-view .glossaryList li *{
    all: unset;
    text-decoration: none;
    display: block;
}
.cm-glossary.cards-view .glossaryList li .glossaryLinkMain span,
.cm-glossary.cards-view .glossaryList li .glossary-link-title span{
    font-weight: bold !important;
    font-size: 24px;
    margin-bottom: 13px;
    display: inline-block;
    width: 100%;
}

@media screen and (max-width: 600px) {
    .cm-glossary.cards-view .glossaryList li:not(.the-index-letter, .the-letter-separator){
        width: 45% !important;
    }
}
@media screen and (max-width: 450px) {
    .cm-glossary.cards-view .glossaryList li:not(.the-index-letter, .the-letter-separator){
        width: 100% !important;
    }
}

/* Styles for Modern Table*/
.cm-glossary.table.modern ul.glossaryList > li {
	list-style: none;
	min-height: 1.5em;
	border: 1px solid #EAEAEA;
	display: flex;
}

.cm-glossary.table.modern ul.glossaryList > li:last-child {
	border-top: none;
}

.cm-glossary.table.modern ul.glossaryList li > .glossaryLink,
.cm-glossary.table.modern ul.glossaryList li > .glossaryLinkMain {
	list-style: none;
	margin: 0.5em;
	display: inline;
	width: 33%;
}

.cm-glossary.table.modern ul.glossaryList li > .glossary_itemdesc {
	list-style: none;
	min-height: 3em;
	padding: 0.5em 0 0.5em 2%;
	border-left: 1px solid #E5E5E5;
	word-wrap: break-word;
	flex: 1;
}

.cm-glossary.table.modern ul.glossaryList li.the-index-letter {
	font-size: 20px;
	line-height: 1.5em;
	text-transform: uppercase;
	clear: both;
	width: 100%;
	padding: 5px 0;
	border: none;
}

.cm-glossary.table ul.glossaryList li.the-index-letter > * {
	margin: 0;
	padding: 0;
}

.cm-glossary.table.modern ul.glossaryList li.the-letter-separator {
	clear: both;
	width: 100%;
	border: none;
	height: 0;
	margin: 0;
	min-height: 0;
}

/* Language Table view */
.cm-glossary.language-table ul > li {
	margin: 15px 0;
	display: grid;
	border-top: 1px solid rgb(192, 192, 192);
	justify-content: space-between;
	grid-gap: 15px;
}

.cm-glossary.language-table ul > li:first-child {
	border: none;
}

.cm-glossary.language-table .cmtt-language-table-header .current {
	grid-column: 1 / span 1;
	grid-row: 1 / 1;
}

select#glossary-languages {
	width: auto;
	margin: 10px 10px 10px 0;
}
/*!/wp-content/plugins/TooltipProPlus/assets/css/tooltip.min.css*/
#tt,#tt.amp-tooltip{position:absolute;z-index:1500;opacity:.95;width:auto;display:none}#tt.amp-tooltip{display:block;max-width:300px}#tt iframe{max-width:99%}.centerflp-content{opacity:0!important;transform:scale3d(0,1,0);transform-origin:50% 120%;transition:opacity .5s,transform .5s;transition-timing-function:ease,cubic-bezier(.6,0,.4,1);display:block}.force-hide{visibility:hidden}.flipInY{display:block!important}.no-ani-with-flip{opacity:1!important;transform:scale3d(1,1,1)}.zoomIn,.zoomOut{transform-origin:top center}.centerflp-content.tooltip-bloated-content{opacity:1!important;pointer-events:auto;-webkit-transform:scale3d(1,1,1)!important;transform:scale3d(1,1,1)!important}.no-in{display:none}.has-in{transform:scale3d(0,1,0);transform-origin:50% 120%}.cmtt_help{background-image:url(/wp-content/plugins/TooltipProPlus/assets/css/images/help.png);width:15px;height:15px;display:inline-block;cursor:pointer}.cmtt_field_help{margin:0 -20px 0 0;float:right}.cmtt_field_help:hover,.cmtt_help:hover{background-image:url(/wp-content/plugins/TooltipProPlus/assets/css/images/help_hover.png)}.cmtt_help{margin-right:5px}#tt.out{-webkit-animation-name:out;-webkit-animation-duration:4s;animation-name:out;animation-duration:0.5s;animation-iteration-count:1;transform:scale3d(0,1,0);transform-origin:50% 120%}#tt.in{-webkit-animation-name:in;-webkit-animation-duration:4s;animation-name:in;animation-duration:0.5s;animation-iteration-count:1;transform:scale3d(1,1,1);transform-origin:50% 120%}@keyframes in{from{transform:scale3d(0,1,0);transform-origin:50% 120%}to{transform:scale3d(1,1,1);transform-origin:50% 120%}}@keyframes out{from{transform:scale3d(1,1,1);transform-origin:50% 120%}to{transform:scale3d(0,1,0);transform-origin:50% 120%}}#tt.vertical_top:before{z-index:111;content:'';position:absolute;border:9px solid #fff0;border-top:0;border-bottom:9px solid #fff0;top:-9px;left:48%}#tt.vertical_top:after{z-index:111;content:'';position:absolute;border:9px solid #fff0;border-top:0;border-bottom:9px solid #fff0;top:-8px;left:48%}#tt.vertical_bottom:before{z-index:111;content:'';position:absolute;border:9px solid #fff0;border-bottom:0;border-top:9px solid #fff0;bottom:-9px;left:170px}#tt.vertical_bottom:after{content:'';position:absolute;border:9px solid #fff0;border-bottom:0;border-top:9px solid #fff0;bottom:-8px;left:170px;z-index:112}#tttop{display:block}#ttcont{display:block;padding:20px;margin-left:5px;background:#333;color:#fff;overflow:auto}#ttbot{display:block;margin-left:5px}#ttcont iframe{max-width:99%}#ttcont ol,#ttcont ul{list-style-position:inside}#ttcont>img{display:block}.cmtt-clearfix{clear:both}.cmtt-backlink{display:block;margin:10px 0}.cmtt-glossary-tooltip-toggle-wrapper{margin:10px 0}.cmtt-tooltip-overlay{display:inline-block;position:relative}.cmtt-tooltip-overlay-icon{display:inline-block;position:absolute;top:0;right:0}.cmtt_longtext{width:300px}.cmtt-tooltip-overlay-icon:after{position:absolute;top:0;right:0;content:'';width:15px;height:15px;background:url(/wp-content/plugins/TooltipProPlus/assets/css/images/tooltip-image-overlay-icon.png);background-repeat:no-repeat;background-position:center center;background-color:#fff0;z-index:1400;background-size:100%}#tt #tt-btn-close,#amp-tt #tt-btn-close{width:16px;height:16px;z-index:999999;background-position:-80px -128px;position:absolute;right:0;top:0;cursor:pointer;font-size:20px;font-family:dashicons;color:#222;direction:rtl;background-color:transparent!important;padding:10px!important;border:none!important;-webkit-tap-highlight-color:#fff0}#tt #tt-btn-close:focus,#amp-tt #tt-btn-close:focus{caret-color:transparent!important}ul#glossaryList{padding:0;margin:0;list-style-type:none!important}div.glossary-container>ul.pageNumbers{padding-top:20px}div.glossary-container>p br{display:none}span.glossaryLink,a.glossaryLink,div.glossaryLink{text-decoration:none!important;border-bottom:dotted 1px}span.glossaryLink.hasDashicon,a.glossaryLink.hasDashicon{border-bottom:none!important}a.glossaryLink:hover{text-decoration:none!important}span.glossaryLink.hasDashicon:hover,a.glossaryLink.hasDashicon:hover{border-bottom:none!important;text-decoration:none!important}span.glossaryLink:focus,a.glossaryLink:focus,#tt-btn-close{outline:none}#glossary-categories{float:right;margin:0}.glossary-category-wrapper{float:right;display:flex;align-items:center}.glossary-category-wrapper label{margin-right:10px}.mobile-link{margin:10px 0;font-size:14px}.mobile-link:before{content:"Term link: "}h4.cmtt_related_title{margin-bottom:0;margin-top:20px}div.cmtt_related_title{margin-bottom:0;margin-top:20px;font-weight:700}.glossary_itemdesc .cmtt_related_title{margin-top:5px}ul.cmtt_related{margin-top:0;clear:none}li.cmtt_related_item{margin-bottom:10px}div.cmtt_synonyms{margin-bottom:1em;font-style:italic}div.cmtt_synonyms_title{margin-bottom:0;margin-top:20px;font-weight:700}div.glossaryItemTitle{margin:10px 0}#ttcont div.glossaryTooltipMoreLinkWrapper{padding:2px 12px 3px 7px}#ttcont div.glossaryTooltipMoreLinkWrapper:after{content:" \2192"}.glossary_top_filter{clear:both;overflow:hidden;margin:10px 0}.cmtt-tags-filter{margin:10px 0 0}.cmtt-tags-filter a.cmtt-glossary-tag{cursor:pointer;border-left:1px solid;margin:0 0 0 5px;padding:0 0 0 5px}.cmtt-tags-filter a.cmtt-glossary-tag:first-child{border:none;padding:0;margin:0}.cmtt-tags-filter a.cmtt-glossary-tag.selected{text-decoration:underline;font-weight:700}.cmtt-categories-filter a.cmtt-glossary-category{cursor:pointer;margin:0 0 0 1px;background:#a8a8a8;color:white!important;border:1px solid;border-radius:25px;padding:5px;font-weight:700!important}.cmtt-categories-filter a.selected{background:#696969!important;color:white!important}.cmtt-categories-filter{margin:10px 0 0;padding:10px 0 10px 0;line-height:35px}.cmtt-categories-filter a.cmtt-glossary-category:first-child{border:none}.cmtt-categories-filter a.cmtt-glossary-category.selected{text-decoration:underline;font-weight:700}.glossary_top_filter .right{float:right}.cmtt-glossary-replacement-add{border:1px solid #CCC;border-radius:5px;background:#EEE;margin-top:30px;padding-bottom:12px}.cmtt-glossary-replacement-add input.invalid{border:1px solid red}.glossary_loading{background:url(/wp-content/plugins/TooltipProPlus/assets/css/images/ajax-loader.gif) no-repeat center center;background-color:#DDD;position:absolute;width:100%;height:100%;opacity:.5;display:none}.glossary_replacements_list tr:hover{background-color:#EEE}.glossary_replacements_list th{font-weight:700}.glossarySettingsTabs .block{border:1px solid grey;border-radius:13px;padding:20px;margin:5px;float:none;width:auto}.glossarySettingsTabs .block h3{padding-top:0;margin-top:0}#glossary-exclude-box label.blocklabel,#glossary-disable-box label.blocklabel{display:block}div#glossary-exclude-box div div{margin:5px 0}.floated-form-table{clear:none}.floated-form-table tr{float:left;width:49%;clear:none}.floated-form-table tr.whole-line{width:99%}.glossarySettingsTabs table th{position:relative;padding-right:25px}div.cmtt_field_help{display:inline-block;width:15px;height:15px;background-image:url(/wp-content/plugins/TooltipProPlus/assets/css/images/help.png);cursor:pointer;margin:0 -20px 0 0;float:right}div.cmtt_field_help:hover{background-image:url(/wp-content/plugins/TooltipProPlus/assets/css/images/help_hover.png)}div.cmtt_help{display:inline-block;width:15px;height:15px;background-image:url(/wp-content/plugins/TooltipProPlus/assets/css/images/help.png);cursor:pointer;margin-right:5px}div.cmtt_help:hover{background-image:url(/wp-content/plugins/TooltipProPlus/assets/css/images/help_hover.png)}.cm-showhide-handle{cursor:pointer}.glossary-container{position:relative}.glossary-search-clear{margin-left:1em;cursor:pointer}#glossary-search-term{padding-left:5px;padding-right:5px}#tt .mobile-link a.glossaryLinkMain,#tt div.glossary_mw_dictionary,#tt div.mw-thesaurus-container,#tt h1,#tt h2,#tt h3,#tt h4{color:#fff}div.mw-dictionary-container{margin-top:1em}div.mw-thesaurus-container{margin-top:2em}.mw-wikipedia-container table.infobox,.mw-wiktionary-container table.infobox{float:right;font-size:8pt;margin-left:5px}div.glossary_mw_dictionary,div.glossary_mw_wikipedia,.glossary_mw_wiktionary{font-size:14pt;margin:.5em 0 .5em 0}div.mw-group{margin:.5em 0}div.mw-group .group-title{font-size:12pt;margin-top:.5em;margin-bottom:.5em}div.mw-group .term{margin-top:.3em}div.mw-group div.term-number{float:left;font-weight:700}div.mw-group div.dd,div.mw-group dd{margin:0 0 0 1.5em}div.mw-group .type-vt{margin-left:1em}div.mw-group .sn{margin-left:2em;margin-right:.5em}div.mw-group .prdiv{margin-left:.5em}div.mw-group .prdiv+.sn{margin-left:.5em}#tt span.example:before{content:"<"}#tt span.example:after{content:">"}span.definition{margin-left:.5em}div.mw-group.mw-definitnion{font-family:monospace;border:1px #ccc solid;border-radius:5px;display:block;padding:10px}div.scnt{margin-top:1em}.progress-indicator{top:0;right:0;width:100%;height:100%;position:absolute;text-align:center;filter:alpha(opacity=50);opacity:.5;z-index:1000;background-color:#fff;display:none}.progress-indicator img{margin-top:75px}.cmtt-post-format-icon:before{font:200 14px/1 dashicons;position:relative;left:-5px}.cmtt-post-format-icon.cmtt-post-format-audio:before{content:"\f521";font-size:.8em}.cmtt-post-format-icon.cmtt-post-format-new:before{content:'\f155'}.cmtt-post-format-icon.cmtt-post-format-new{display:inline}.cmtt-audio-shortcode{margin:10px}.cmtt-audio-player.cmtt-limited{float:right;font:200 14px/1 dashicons}.cmtt-audio-player.cmtt-limited .cmtt-audio-shortcode .mejs-controls>*:not(.mejs-playpause-button){display:none!important}.cmtt-audio-player.cmtt-limited .cmtt-audio-shortcode.mejs-container{width:auto!important;height:auto!important;background:none!important}.cmtt-audio-player.cmtt-limited .cmtt-audio-shortcode .mejs-controls{width:auto!important;background:none!important;position:initial!important}.cmtt-audio-player .cmtt-audio-shortcode .mejs-controls{position:initial!important}.cmtt-woocommerce-product-container{padding:.2em}.cmtt-woocommerce-product-image-container{float:left;padding:5px 10px 10px 0}.cmtt-woocommerce-product-description{padding-bottom:1em;display:block}.cmtt-woocommerce-product-desc-container{min-width:275px}.cmtt-woocommerce-product-name{width:100%;display:block;font-weight:800}.cmtt-woocommerce-product-button-container{width:100%;display:block;float:inline-end;margin:0 0 10px 0}.cmtt-woocommerce-product-price ins{background:none}.cmtt-post-tags a{cursor:pointer}.cmtt-taxonomy-single a{cursor:pointer}.server-info-table span{color:green;font-weight:700}.server-info-table strong{color:red;font-weight:700}.cmtt-social-box{width:auto;display:flex;margin-bottom:10px;padding:0}.cmtt-social-box>div{height:25px;max-width:68px;margin:4px 4px 0 0}.cmtt-social-box .sharetitle{border-right:1px solid #D2D2D2;padding:0 10px 0 0;margin:0 10px 0 0;line-height:25px;vertical-align:middle;display:inline-block;font-size:large;font-weight:700;max-width:fit-content}.cmtt-social-box>div>*{vertical-align:top!important}select#cmtt_glossaryID{max-width:350px}div.cminds_settings_description{float:left;max-width:55%;margin-bottom:20px}li.cmtt-has-thumbnail{list-style-position:inside;list-style-type:none;margin-left:-25px}li.cmtt-has-thumbnail .cmtt-thumbnail{position:relative}li.cmtt-has-thumbnail .cmtt-thumbnail-link{position:relative;display:inline-block;border:0!important;outline:none;text-decoration:none!important;-webkit-box-shadow:none!important;box-shadow:none!important;padding:0;margin:0;vertical-align:middle}.cmtt_Media_Image.cmtt_hasThumb{width:70px;height:70px;background-size:cover;background-position:center;margin-bottom:5px;position:relative;cursor:pointer}.cmtt_Media_Image.cmtt_hasThumb::before,.cmtt_Media_Image.cmtt_hasThumb::after{content:'';display:block;position:absolute;width:14px;height:2px;left:50%;top:50%;background:rgb(255 255 255 / .4);margin-top:-1px;margin-left:-7px}.cmtt_Media_Image.cmtt_hasThumb::before{-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);transform:rotate(45deg)}.cmtt_Media_Image.cmtt_hasThumb::after{-webkit-transform:rotate(-45deg);-moz-transform:rotate(-45deg);transform:rotate(-45deg)}.single-sidebar-glossary #primary{margin-left:0;width:70%;float:left;padding-right:15px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.single-sidebar-glossary #secondary{width:30%;float:left;padding-left:15px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.dashicon-picker-container{position:absolute;width:220px;height:252px;font-size:14px;background-color:#fff;-webkit-box-shadow:0 1px 2px rgb(0 0 0 / .1);box-shadow:0 1px 2px rgb(0 0 0 / .1);overflow:hidden;padding:5px;box-sizing:border-box;z-index:999}.dashicon-picker-container ul{margin:0;padding:0;margin-bottom:10px}.dashicon-picker-container ul .dashicons{width:20px;height:20px;font-size:20px}.dashicon-picker-container ul li{display:inline-block;margin:5px;float:left}.dashicon-picker-container ul li a{display:block;text-decoration:none;color:#373737;padding:5px 5px;border:1px solid #dfdfdf}.dashicon-picker-container ul li a:hover{border-color:#999;background:#efefef}.dashicon-picker-control{height:32px}.dashicon-picker-control a{padding:5px;text-decoration:none;line-height:32px;width:25px}.dashicon-picker-control a span{display:inline;vertical-align:middle}.dashicon-picker-control input{font-size:12px;width:140px}.cmtt_meaning_label{margin:10px 0}body.cmtt-embed{margin:0!important;padding:0!important;overflow:hidden;background:#fff}body.cmtt-embed .cmtt-embedded{margin:25px 5px}.cmtt-embed-btn{margin:5px 0}.cmtt-embed-modal{display:none;background:#fff;padding:2em;width:600px}.cmtt-embed-modal textarea{width:100%;height:7em;margin-top:1em}body.cmtt-embed .zopim{display:none!important;visibility:hidden!important}.cmtt-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgb(50 50 50 / .9);z-index:9999998}.cmtt-overlay-content-outer{position:fixed;top:10%;left:50%;width:auto;z-index:9999999}.cmtt-overlay-content{background:#fff;margin-left:-50%;width:100%;position:relative}.cmtt-overlay-close{font:normal 24px Arial;color:#666;position:absolute;top:0;right:3px;cursor:pointer}.glossaryLink.ampGlossaryLink{position:relative}.glossaryLink.ampGlossaryLink #tt{top:110%;left:-50%}.cmtt-footnote-header-border{border-top:1px solid lightgrey;width:100%;margin-bottom:15px}.cmtt-footnote-bottom-border{border-top:1px solid lightgrey;width:100%;margin-top:15px;margin-bottom:15px}.cmtt-footnote-def.hidden{display:none}.cmtt-footnote-def-key{font-style:oblique;font-weight:500}.cmtt-footnote-def-content{font-size:small}#tt_overlay{position:fixed;inset:0;background:rgb(0 0 0 / .5);display:none}.tt-box-bottom{bottom:0!important;right:0!important;left:0!important;top:auto!important;width:100%!important;max-width:100%!important}.tt-box-bottom::before{top:-20px;left:50%;transform:translateX(-50%);width:34px;height:28px;background:url("data:image/svg+xml;utf8,<svg width='34' height='14' viewBox='0 0 34 14' xmlns='http://www.w3.org/2000/svg'><path d='M2 2 L17 12 L32 2' stroke='%23fff' stroke-width='4' fill='none' stroke-linecap='round'/></svg>") no-repeat top center;background-size:34px 14px,cover}.tt-box-bottom::before,.tt-box-right::before,.tt-box-left::before{content:"";position:absolute;cursor:pointer;pointer-events:auto;z-index:99999}.tt-box-left::before{top:50%;right:-25px;transform:translateY(-50%);width:28px;height:34px;background:url("data:image/svg+xml;utf8,<svg width='14' height='34' viewBox='0 0 14 34' xmlns='http://www.w3.org/2000/svg'><path d='M12 2 L2 17 L12 32' stroke='%23fff' stroke-width='4' fill='none' stroke-linecap='round'/></svg>") no-repeat center center;background-size:14px 34px}.tt-box-right::before{top:50%;left:-25px;transform:translateY(-50%);width:28px;height:34px;background:url("data:image/svg+xml;utf8,<svg width='14' height='34' viewBox='0 0 14 34' xmlns='http://www.w3.org/2000/svg'><path d='M2 2 L12 17 L2 32' stroke='%23fff' stroke-width='4' fill='none' stroke-linecap='round'/></svg>") no-repeat center center;background-size:14px 34px}.tt-box-bottom #ttcont,.tt-box-right #ttcont,.tt-box-left #ttcont{max-height:100%;min-height:30%;margin:0px!important;width:100%!important}#tt.tt-box-bottom{flex-direction:column;will-change:transform;transition:transform 0.25s ease;max-height:50%}#tt.tt-box-bottom.dragging{transition:none!important}#tt.tt-box-bottom.dragging{transition:none}.tt-drag-handle{position:absolute;cursor:grab;touch-action:none;background:#fff0;z-index:9999999}.tt-box-bottom .tt-drag-handle{top:0;left:0;right:0;height:32px;transform:translateY(-100%)}.tt-box-right .tt-drag-handle{top:auto;bottom:auto;left:0;width:32px;transform:translateX(-100%)}.tt-box-left .tt-drag-handle{top:auto;bottom:auto;right:0;width:32px;transform:translateX(100%)}.tt-box-right,.tt-box-left{top:0!important;width:300px!important;max-width:400px;min-width:200px;height:100%}body.admin-bar .tt-box-right,body.admin-bar .tt-box-left{top:32px!important;max-height:calc(100% - 32px)!important}.tt-box-left{right:auto!important;left:0!important}.tt-box-right{right:0!important;left:auto!important}#tt.tt-box-right #tt-btn-close,#amp-tt.tt-box-right #tt-btn-close,#tt.tt-box-left #tt-btn-close,#amp-tt.tt-box-left #tt-btn-close{right:10px}@keyframes slideUp{from{transform:translateY(60px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{from{transform:translateY(0);opacity:1}to{transform:translateY(60px);opacity:0}}@keyframes slideInLeft{from{transform:translate(-400px,0);opacity:0}to{transform:translate(0,0);opacity:1}}@keyframes slideInRight{from{transform:translate(400px,0);opacity:0}to{transform:translate(0,0);opacity:1}}@keyframes slideOutLeft{from{transform:translate(0,0);opacity:1}to{transform:translate(-400px,0);opacity:0}}@keyframes slideOutRight{from{transform:translate(0,0);opacity:1}to{transform:translate(400px,0);opacity:0}}
/* [inline: after] */#tt {
				z-index: 1500;
		}
		#tt_overlay {
				z-index: 1499;
		}
        #tt #ttcont div.glossaryItemTitle {
            width: calc(100% + -16);
            border-top-left-radius: 6px;
            border-top-right-radius: 6px;
            padding: 0;
            text-align: initial;
            margin: -12px -16px 10px -16px;
            line-height: inherit;
            font-weight: normal;
		
		
					font-size: 13px !important;
		        }

		#tt #ttcont div.glossaryItemBody {
		padding: 0;
					font-size: 13px;
		                    line-height: inherit;
        		}
		#tt #ttcont .mobile-link{
					font-size: 13px;
				}

		.mobile-link a.glossaryLink {
		color: #fff !important;
		}
		.mobile-link:before{content: "Term link: "}

		
		
		.tiles ul.glossaryList li {
		min-width: 85px !important;
		width:85px !important;
		}
		.tiles ul.glossaryList span { min-width:85px; width:85px;  }
		.cm-glossary.tiles.big ul.glossaryList a { min-width:179px; width:179px }
		.cm-glossary.tiles.big ul.glossaryList span { min-width:179px; width:179px; }

				span.glossaryLink, a.glossaryLink {
		border-bottom: dotted 1px #000000;					color: #004cff !important;
				}
		span.glossaryLink.temporary, a.glossaryLink.temporary {
		border-bottom: dotted 1px ;		}
		span.glossaryLink:hover, a.glossaryLink:hover {
		border-bottom: solid 1px #333333;					color:#333333 !important;
				}

				.glossaryList .glossary-link-title {
		font-weight: normal !important;
		}

		
					#tt #tt-btn-close{ color: #93b7ff !important}
		
		.cm-glossary.grid ul.glossaryList li:not(.the-index-letter)  { width: 200px !important}

					#tt #tt-btn-close{
			direction: rtl;
			font-size: 20px !important
			}
		
					div.cmtt_help {
			background-image: url(https://www.flexoffers.com/wp-content/blogs.dir/4/files/2023/12/magnifying-glass.png);
			background-size: contain;
			}
			div.cmtt_help:hover {
			background-image: url(https://www.flexoffers.com/wp-content/blogs.dir/4/files/2023/12/magnifying-glass.png);
			}
		
					#tt #ttcont glossaryItemBody * {color: #ffffff}
		

		
		
		
		
					#ttcont {
			box-shadow: 0px 0px 20px #9e9e9e;
			-moz-box-shadow: 0px 0px 20px #9e9e9e;
			-webkit-box-shadow: 0px 0px 20px #9e9e9e;
			}
					.cm-glossary.term-carousel .slick-slide,
			.cm-glossary.tiles-with-definition ul > li { height: 245px !important}
					.cm-glossary.tiles-with-definition ul {
			grid-template-columns: repeat(auto-fill, 220px) !important;
			}
		            :not(.cube) > .glossary-container > #glossaryList-nav > .ln-letters {
			width: 100%;
			display: flex;
			flex-wrap: wrap;
			}
            :not(.cube) > .glossary-container > #glossaryList-nav > .ln-letters a {
			text-align: center;
			flex-grow: 1;
			}
					.cm-glossary #glossary-search {
			background-color: #0038f2 !important;
			}
					.cm-glossary #glossary-search {
			color: #ffffff !important;
			}
					.cm-glossary #glossary-search:hover {
			color: #ffffff !important;
			}
					.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList {
			grid-template-columns: repeat(6, 1fr);
			}
			.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList > li > div.term-block > .glossaryLinkMain,
			.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList > li > div.term-block > .glossaryLink,
			.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList .glossary_itemdesc .glossary-read-more-link {
			background-color: #cecece;
			}
			.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList > li,
			.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList > li > div.term-block > .glossaryLinkMain,
			.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList > li > div.term-block > .glossaryLink,
			.cm-glossary.flipboxes-with-definition #glossaryList.glossaryList > li > div.term-block > .glossary_itemdesc {
			height: 160px;
			}
		
            .cm-glossary.accordion-view .ln-letters a, .cm-glossary.accordion-view-2 .ln-letters a{
            color: ;
            }

            .cm-glossary.accordion-view .glossaryList li.active-term .glossaryLinkMain, .cm-glossary.accordion-view-2 .glossaryList li.active .glossaryLinkMain,
            .cm-glossary.accordion-view .glossaryList li.active-term .glossary-link-title, .cm-glossary.accordion-view-2 .glossaryList li.active .glossary-link-title{
            color:  !important;
            }

            .cm-glossary.accordion-view .glossaryList li .glossaryLinkMain span.dashicons, .cm-glossary.accordion-view-2 .glossaryList li.active .glossaryLinkMain:after,
            .cm-glossary.accordion-view .glossaryList li .glossary-link-title span.dashicons, .cm-glossary.accordion-view-2 .glossaryList li.active .glossary-link-title:after{
            color: #8e2c85;
            }

            .cm-glossary.accordion-view-2 .glossaryList li{
            border-color:   ;
            }

            .cm-glossary.accordion-view .the-index-letter{
            background-color: ;
            }

            .cm-glossary.accordion-view .the-index-letter > *, .cm-glossary.accordion-view-2 .the-index-letter > * {
            color: ;
            }

        
            .cm-glossary.cards-view .ln-letters {
                border: none;
                text-align: center;
            }

            .cm-glossary.cards-view .ln-letters a{
                color: #000;
                width: fit-content;
                border: none;
                font-weight: bold;
                display: inline-block;
                float: unset;
                font-size: 13px;
            }

            .cm-glossary.cards-view .ln-letters .ln-disabled{
                opacity: 0.4;
                cursor: default;
            }

            .cm-glossary.cards-view .glossaryList {
                display: flex;
                flex-wrap: wrap;
                gap: 10px;
                padding: 0;
                width: 100%;
                justify-content: flex-start;
            }

            .cm-glossary.cards-view .glossaryList li.the-index-letter{
                width:100% !important;
                font-size: 30px;
                font-weight: bold;
                color: #000;
            }

            .cm-glossary.cards-view .glossaryList li.the-index-letter *{
                margin: 0 0 15px 15px;
            }

            .cm-glossary.cards-view .glossaryList li:not(.the-index-letter, .the-letter-separator){
                display: flex;
                font-weight: normal;
                width: 30%;
                float: left;
                margin: 0 1% 10px;
                list-style: none;
                background-color: #fff !important;
                color: #00000;
                border: 1px solid #ededf2;
                padding: 13px !important;
                box-shadow: 0 0.625rem 3.125rem rgba(12, 39, 19, 0.2);
                transition: border-top-color .2s ease-in-out, border-top-width .2s ease-in-out, box-shadow .2s ease-in-out;
            }

            .cm-glossary.cards-view .glossaryList li .glossaryLinkMain,
            .cm-glossary.cards-view .glossaryList li .glossary-link-title {
                color: #00000 !important;
                border: none !important;
                width: 100%;
            }

            .cm-glossary.cards-view .glossaryList li .glossary_itemdesc {
                color: #000 !important;
            }

            .cm-glossary.cards-view .glossaryList li *{
                all: unset;
                text-decoration: none;
                display: block;
            }

            .cm-glossary.cards-view .glossaryList li:not(.the-index-letter, .the-letter-separator):hover{
                border-top-width: 2px;
                border-top-color: #6bc07f;
                box-shadow: 0 0.625rem 3.125rem rgba(0, 0, 0, .1);
            }

            .cm-glossary.cards-view .glossaryList li:hover .glossaryLinkMain span,
            .cm-glossary.cards-view .glossaryList li:hover .glossary-link-title span{
                color: #6bc07f !important;
            }


        
		.glossary-search-wrapper {
		display: inline-block;
				}


		
		input.glossary-search-term {
				outline: none;
					border-width: 1px;
							border-style: solid;
							border-color: #dddddd;
												}


		
		
		button.glossary-search.button {
		outline: none;
							border-style: none;
										}
/* [/inline: after] */
/*!/wp-content/plugins/TooltipProPlus/assets/css/animate.css*/
@charset "UTF-8";

/*!
 * animate.css -http://daneden.me/animate
 * Version - 3.6.0
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2018 Daniel Eden
 */

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}

@-webkit-keyframes bounce {
  from,
  20%,
  53%,
  80%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  40%,
  43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0);
  }

  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, -4px, 0);
    transform: translate3d(0, -4px, 0);
  }
}

@keyframes bounce {
  from,
  20%,
  53%,
  80%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  40%,
  43% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -30px, 0);
    transform: translate3d(0, -30px, 0);
  }

  70% {
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    -webkit-transform: translate3d(0, -15px, 0);
    transform: translate3d(0, -15px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, -4px, 0);
    transform: translate3d(0, -4px, 0);
  }
}

.bounce {
  -webkit-animation-name: bounce;
  animation-name: bounce;
  -webkit-transform-origin: center bottom;
  transform-origin: center bottom;
}

@-webkit-keyframes flash {
  from,
  50%,
  to {
    opacity: 1;
  }

  25%,
  75% {
    opacity: 0;
  }
}

@keyframes flash {
  from,
  50%,
  to {
    opacity: 1;
  }

  25%,
  75% {
    opacity: 0;
  }
}

.flash {
  -webkit-animation-name: flash;
  animation-name: flash;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@-webkit-keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes pulse {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

.pulse {
  -webkit-animation-name: pulse;
  animation-name: pulse;
}

@-webkit-keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1);
  }

  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1);
  }

  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1);
  }

  65% {
    -webkit-transform: scale3d(0.95, 1.05, 1);
    transform: scale3d(0.95, 1.05, 1);
  }

  75% {
    -webkit-transform: scale3d(1.05, 0.95, 1);
    transform: scale3d(1.05, 0.95, 1);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes rubberBand {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  30% {
    -webkit-transform: scale3d(1.25, 0.75, 1);
    transform: scale3d(1.25, 0.75, 1);
  }

  40% {
    -webkit-transform: scale3d(0.75, 1.25, 1);
    transform: scale3d(0.75, 1.25, 1);
  }

  50% {
    -webkit-transform: scale3d(1.15, 0.85, 1);
    transform: scale3d(1.15, 0.85, 1);
  }

  65% {
    -webkit-transform: scale3d(0.95, 1.05, 1);
    transform: scale3d(0.95, 1.05, 1);
  }

  75% {
    -webkit-transform: scale3d(1.05, 0.95, 1);
    transform: scale3d(1.05, 0.95, 1);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

.rubberBand {
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand;
}

@-webkit-keyframes shake {
  from,
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  10%,
  30%,
  50%,
  70%,
  90% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }

  20%,
  40%,
  60%,
  80% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
}

@keyframes shake {
  from,
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  10%,
  30%,
  50%,
  70%,
  90% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }

  20%,
  40%,
  60%,
  80% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
}

.shake {
  -webkit-animation-name: shake;
  animation-name: shake;
}

@-webkit-keyframes headShake {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }

  6.5% {
    -webkit-transform: translateX(-6px) rotateY(-9deg);
    transform: translateX(-6px) rotateY(-9deg);
  }

  18.5% {
    -webkit-transform: translateX(5px) rotateY(7deg);
    transform: translateX(5px) rotateY(7deg);
  }

  31.5% {
    -webkit-transform: translateX(-3px) rotateY(-5deg);
    transform: translateX(-3px) rotateY(-5deg);
  }

  43.5% {
    -webkit-transform: translateX(2px) rotateY(3deg);
    transform: translateX(2px) rotateY(3deg);
  }

  50% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

@keyframes headShake {
  0% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }

  6.5% {
    -webkit-transform: translateX(-6px) rotateY(-9deg);
    transform: translateX(-6px) rotateY(-9deg);
  }

  18.5% {
    -webkit-transform: translateX(5px) rotateY(7deg);
    transform: translateX(5px) rotateY(7deg);
  }

  31.5% {
    -webkit-transform: translateX(-3px) rotateY(-5deg);
    transform: translateX(-3px) rotateY(-5deg);
  }

  43.5% {
    -webkit-transform: translateX(2px) rotateY(3deg);
    transform: translateX(2px) rotateY(3deg);
  }

  50% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }
}

.headShake {
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-name: headShake;
  animation-name: headShake;
}

@-webkit-keyframes swing {
  20% {
    -webkit-transform: rotate3d(0, 0, 1, 15deg);
    transform: rotate3d(0, 0, 1, 15deg);
  }

  40% {
    -webkit-transform: rotate3d(0, 0, 1, -10deg);
    transform: rotate3d(0, 0, 1, -10deg);
  }

  60% {
    -webkit-transform: rotate3d(0, 0, 1, 5deg);
    transform: rotate3d(0, 0, 1, 5deg);
  }

  80% {
    -webkit-transform: rotate3d(0, 0, 1, -5deg);
    transform: rotate3d(0, 0, 1, -5deg);
  }

  to {
    -webkit-transform: rotate3d(0, 0, 1, 0deg);
    transform: rotate3d(0, 0, 1, 0deg);
  }
}

@keyframes swing {
  20% {
    -webkit-transform: rotate3d(0, 0, 1, 15deg);
    transform: rotate3d(0, 0, 1, 15deg);
  }

  40% {
    -webkit-transform: rotate3d(0, 0, 1, -10deg);
    transform: rotate3d(0, 0, 1, -10deg);
  }

  60% {
    -webkit-transform: rotate3d(0, 0, 1, 5deg);
    transform: rotate3d(0, 0, 1, 5deg);
  }

  80% {
    -webkit-transform: rotate3d(0, 0, 1, -5deg);
    transform: rotate3d(0, 0, 1, -5deg);
  }

  to {
    -webkit-transform: rotate3d(0, 0, 1, 0deg);
    transform: rotate3d(0, 0, 1, 0deg);
  }
}

.swing {
  -webkit-transform-origin: top center;
  transform-origin: top center;
  -webkit-animation-name: swing;
  animation-name: swing;
}

@-webkit-keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  10%,
  20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
  }

  30%,
  50%,
  70%,
  90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }

  40%,
  60%,
  80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  10%,
  20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
  }

  30%,
  50%,
  70%,
  90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }

  40%,
  60%,
  80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

.tada {
  -webkit-animation-name: tada;
  animation-name: tada;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@-webkit-keyframes wobble {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
  }

  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
  }

  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
  }

  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
  }

  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes wobble {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
  }

  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
  }

  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
  }

  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
  }

  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.wobble {
  -webkit-animation-name: wobble;
  animation-name: wobble;
}

@-webkit-keyframes jello {
  from,
  11.1%,
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  22.2% {
    -webkit-transform: skewX(-12.5deg) skewY(-12.5deg);
    transform: skewX(-12.5deg) skewY(-12.5deg);
  }

  33.3% {
    -webkit-transform: skewX(6.25deg) skewY(6.25deg);
    transform: skewX(6.25deg) skewY(6.25deg);
  }

  44.4% {
    -webkit-transform: skewX(-3.125deg) skewY(-3.125deg);
    transform: skewX(-3.125deg) skewY(-3.125deg);
  }

  55.5% {
    -webkit-transform: skewX(1.5625deg) skewY(1.5625deg);
    transform: skewX(1.5625deg) skewY(1.5625deg);
  }

  66.6% {
    -webkit-transform: skewX(-0.78125deg) skewY(-0.78125deg);
    transform: skewX(-0.78125deg) skewY(-0.78125deg);
  }

  77.7% {
    -webkit-transform: skewX(0.390625deg) skewY(0.390625deg);
    transform: skewX(0.390625deg) skewY(0.390625deg);
  }

  88.8% {
    -webkit-transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
    transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
  }
}

@keyframes jello {
  from,
  11.1%,
  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  22.2% {
    -webkit-transform: skewX(-12.5deg) skewY(-12.5deg);
    transform: skewX(-12.5deg) skewY(-12.5deg);
  }

  33.3% {
    -webkit-transform: skewX(6.25deg) skewY(6.25deg);
    transform: skewX(6.25deg) skewY(6.25deg);
  }

  44.4% {
    -webkit-transform: skewX(-3.125deg) skewY(-3.125deg);
    transform: skewX(-3.125deg) skewY(-3.125deg);
  }

  55.5% {
    -webkit-transform: skewX(1.5625deg) skewY(1.5625deg);
    transform: skewX(1.5625deg) skewY(1.5625deg);
  }

  66.6% {
    -webkit-transform: skewX(-0.78125deg) skewY(-0.78125deg);
    transform: skewX(-0.78125deg) skewY(-0.78125deg);
  }

  77.7% {
    -webkit-transform: skewX(0.390625deg) skewY(0.390625deg);
    transform: skewX(0.390625deg) skewY(0.390625deg);
  }

  88.8% {
    -webkit-transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
    transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
  }
}

.jello {
  -webkit-animation-name: jello;
  animation-name: jello;
  -webkit-transform-origin: center;
  transform-origin: center;
}

@-webkit-keyframes bounceIn {
  from,
  20%,
  40%,
  60%,
  80%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  0% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }

  20% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1);
  }

  40% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03);
  }

  80% {
    -webkit-transform: scale3d(0.97, 0.97, 0.97);
    transform: scale3d(0.97, 0.97, 0.97);
  }

  to {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes bounceIn {
  from,
  20%,
  40%,
  60%,
  80%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  0% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }

  20% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1);
  }

  40% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(1.03, 1.03, 1.03);
    transform: scale3d(1.03, 1.03, 1.03);
  }

  80% {
    -webkit-transform: scale3d(0.97, 0.97, 0.97);
    transform: scale3d(0.97, 0.97, 0.97);
  }

  to {
    opacity: 1;
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

.bounceIn {
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-name: bounceIn;
  animation-name: bounceIn;
}

@-webkit-keyframes bounceInDown {
  from,
  60%,
  75%,
  90%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -3000px, 0);
    transform: translate3d(0, -3000px, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, 25px, 0);
    transform: translate3d(0, 25px, 0);
  }

  75% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, 5px, 0);
    transform: translate3d(0, 5px, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes bounceInDown {
  from,
  60%,
  75%,
  90%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -3000px, 0);
    transform: translate3d(0, -3000px, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, 25px, 0);
    transform: translate3d(0, 25px, 0);
  }

  75% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, 5px, 0);
    transform: translate3d(0, 5px, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.bounceInDown {
  -webkit-animation-name: bounceInDown;
  animation-name: bounceInDown;
}

@-webkit-keyframes bounceInLeft {
  from,
  60%,
  75%,
  90%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3000px, 0, 0);
    transform: translate3d(-3000px, 0, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(25px, 0, 0);
    transform: translate3d(25px, 0, 0);
  }

  75% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }

  90% {
    -webkit-transform: translate3d(5px, 0, 0);
    transform: translate3d(5px, 0, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes bounceInLeft {
  from,
  60%,
  75%,
  90%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  0% {
    opacity: 0;
    -webkit-transform: translate3d(-3000px, 0, 0);
    transform: translate3d(-3000px, 0, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(25px, 0, 0);
    transform: translate3d(25px, 0, 0);
  }

  75% {
    -webkit-transform: translate3d(-10px, 0, 0);
    transform: translate3d(-10px, 0, 0);
  }

  90% {
    -webkit-transform: translate3d(5px, 0, 0);
    transform: translate3d(5px, 0, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.bounceInLeft {
  -webkit-animation-name: bounceInLeft;
  animation-name: bounceInLeft;
}

@-webkit-keyframes bounceInRight {
  from,
  60%,
  75%,
  90%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  from {
    opacity: 0;
    -webkit-transform: translate3d(3000px, 0, 0);
    transform: translate3d(3000px, 0, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(-25px, 0, 0);
    transform: translate3d(-25px, 0, 0);
  }

  75% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }

  90% {
    -webkit-transform: translate3d(-5px, 0, 0);
    transform: translate3d(-5px, 0, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes bounceInRight {
  from,
  60%,
  75%,
  90%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  from {
    opacity: 0;
    -webkit-transform: translate3d(3000px, 0, 0);
    transform: translate3d(3000px, 0, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(-25px, 0, 0);
    transform: translate3d(-25px, 0, 0);
  }

  75% {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }

  90% {
    -webkit-transform: translate3d(-5px, 0, 0);
    transform: translate3d(-5px, 0, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.bounceInRight {
  -webkit-animation-name: bounceInRight;
  animation-name: bounceInRight;
}

@-webkit-keyframes bounceInUp {
  from,
  60%,
  75%,
  90%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3000px, 0);
    transform: translate3d(0, 3000px, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  75% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, -5px, 0);
    transform: translate3d(0, -5px, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes bounceInUp {
  from,
  60%,
  75%,
  90%,
  to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }

  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3000px, 0);
    transform: translate3d(0, 3000px, 0);
  }

  60% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  75% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }

  90% {
    -webkit-transform: translate3d(0, -5px, 0);
    transform: translate3d(0, -5px, 0);
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.bounceInUp {
  -webkit-animation-name: bounceInUp;
  animation-name: bounceInUp;
}

@-webkit-keyframes bounceOut {
  20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9);
  }

  50%,
  55% {
    opacity: 1;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }
}

@keyframes bounceOut {
  20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9);
    transform: scale3d(0.9, 0.9, 0.9);
  }

  50%,
  55% {
    opacity: 1;
    -webkit-transform: scale3d(1.1, 1.1, 1.1);
    transform: scale3d(1.1, 1.1, 1.1);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }
}

.bounceOut {
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-name: bounceOut;
  animation-name: bounceOut;
}

@-webkit-keyframes bounceOutDown {
  20% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }

  40%,
  45% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
}

@keyframes bounceOutDown {
  20% {
    -webkit-transform: translate3d(0, 10px, 0);
    transform: translate3d(0, 10px, 0);
  }

  40%,
  45% {
    opacity: 1;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
}

.bounceOutDown {
  -webkit-animation-name: bounceOutDown;
  animation-name: bounceOutDown;
}

@-webkit-keyframes bounceOutLeft {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(20px, 0, 0);
    transform: translate3d(20px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
}

@keyframes bounceOutLeft {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(20px, 0, 0);
    transform: translate3d(20px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
}

.bounceOutLeft {
  -webkit-animation-name: bounceOutLeft;
  animation-name: bounceOutLeft;
}

@-webkit-keyframes bounceOutRight {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(-20px, 0, 0);
    transform: translate3d(-20px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
}

@keyframes bounceOutRight {
  20% {
    opacity: 1;
    -webkit-transform: translate3d(-20px, 0, 0);
    transform: translate3d(-20px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
}

.bounceOutRight {
  -webkit-animation-name: bounceOutRight;
  animation-name: bounceOutRight;
}

@-webkit-keyframes bounceOutUp {
  20% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }

  40%,
  45% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
}

@keyframes bounceOutUp {
  20% {
    -webkit-transform: translate3d(0, -10px, 0);
    transform: translate3d(0, -10px, 0);
  }

  40%,
  45% {
    opacity: 1;
    -webkit-transform: translate3d(0, 20px, 0);
    transform: translate3d(0, 20px, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
}

.bounceOutUp {
  -webkit-animation-name: bounceOutUp;
  animation-name: bounceOutUp;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.fadeIn {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
}

@-webkit-keyframes fadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.fadeInDown {
  -webkit-animation-name: fadeInDown;
  animation-name: fadeInDown;
}

@-webkit-keyframes fadeInDownBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInDownBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.fadeInDownBig {
  -webkit-animation-name: fadeInDownBig;
  animation-name: fadeInDownBig;
}

@-webkit-keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInLeft {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.fadeInLeft {
  -webkit-animation-name: fadeInLeft;
  animation-name: fadeInLeft;
}

@-webkit-keyframes fadeInLeftBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInLeftBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.fadeInLeftBig {
  -webkit-animation-name: fadeInLeftBig;
  animation-name: fadeInLeftBig;
}

@-webkit-keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInRight {
  from {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.fadeInRight {
  -webkit-animation-name: fadeInRight;
  animation-name: fadeInRight;
}

@-webkit-keyframes fadeInRightBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInRightBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.fadeInRightBig {
  -webkit-animation-name: fadeInRightBig;
  animation-name: fadeInRightBig;
}

@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp;
}

@-webkit-keyframes fadeInUpBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes fadeInUpBig {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.fadeInUpBig {
  -webkit-animation-name: fadeInUpBig;
  animation-name: fadeInUpBig;
}

@-webkit-keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

.fadeOut {
  -webkit-animation-name: fadeOut;
  animation-name: fadeOut;
}

@-webkit-keyframes fadeOutDown {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}

@keyframes fadeOutDown {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}

.fadeOutDown {
  -webkit-animation-name: fadeOutDown;
  animation-name: fadeOutDown;
}

@-webkit-keyframes fadeOutDownBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
}

@keyframes fadeOutDownBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
}

.fadeOutDownBig {
  -webkit-animation-name: fadeOutDownBig;
  animation-name: fadeOutDownBig;
}

@-webkit-keyframes fadeOutLeft {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}

@keyframes fadeOutLeft {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}

.fadeOutLeft {
  -webkit-animation-name: fadeOutLeft;
  animation-name: fadeOutLeft;
}

@-webkit-keyframes fadeOutLeftBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
}

@keyframes fadeOutLeftBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
}

.fadeOutLeftBig {
  -webkit-animation-name: fadeOutLeftBig;
  animation-name: fadeOutLeftBig;
}

@-webkit-keyframes fadeOutRight {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

@keyframes fadeOutRight {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

.fadeOutRight {
  -webkit-animation-name: fadeOutRight;
  animation-name: fadeOutRight;
}

@-webkit-keyframes fadeOutRightBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
}

@keyframes fadeOutRightBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
}

.fadeOutRightBig {
  -webkit-animation-name: fadeOutRightBig;
  animation-name: fadeOutRightBig;
}

@-webkit-keyframes fadeOutUp {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}

@keyframes fadeOutUp {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}

.fadeOutUp {
  -webkit-animation-name: fadeOutUp;
  animation-name: fadeOutUp;
}

@-webkit-keyframes fadeOutUpBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
}

@keyframes fadeOutUpBig {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
}

.fadeOutUpBig {
  -webkit-animation-name: fadeOutUpBig;
  animation-name: fadeOutUpBig;
}

@-webkit-keyframes flip {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }

  40% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }

  50% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  80% {
    -webkit-transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
}

@keyframes flip {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }

  40% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }

  50% {
    -webkit-transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    transform: perspective(400px) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  80% {
    -webkit-transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
}

.animated.flip {
  -webkit-backface-visibility: visible;
  backface-visibility: visible;
  -webkit-animation-name: flip;
  animation-name: flip;
}

@-webkit-keyframes flipInX {
  from {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  60% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}

@keyframes flipInX {
  from {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  60% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}

.flipInX {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInX;
  animation-name: flipInX;
}

@-webkit-keyframes flipInY {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  60% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}

@keyframes flipInY {
  from {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }

  40% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }

  60% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
  }

  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}

.flipInY {
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipInY;
  animation-name: flipInY;
}

@-webkit-keyframes flipOutX {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }

  30% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1;
  }

  to {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0;
  }
}

@keyframes flipOutX {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }

  30% {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1;
  }

  to {
    -webkit-transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0;
  }
}

.flipOutX {
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-name: flipOutX;
  animation-name: flipOutX;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
}

@-webkit-keyframes flipOutY {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }

  30% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1;
  }

  to {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0;
  }
}

@keyframes flipOutY {
  from {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }

  30% {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1;
  }

  to {
    -webkit-transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0;
  }
}

.flipOutY {
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipOutY;
  animation-name: flipOutY;
}

@-webkit-keyframes lightSpeedIn {
  from {
    -webkit-transform: translate3d(100%, 0, 0) skewX(-30deg);
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0;
  }

  60% {
    -webkit-transform: skewX(20deg);
    transform: skewX(20deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: skewX(-5deg);
    transform: skewX(-5deg);
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes lightSpeedIn {
  from {
    -webkit-transform: translate3d(100%, 0, 0) skewX(-30deg);
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0;
  }

  60% {
    -webkit-transform: skewX(20deg);
    transform: skewX(20deg);
    opacity: 1;
  }

  80% {
    -webkit-transform: skewX(-5deg);
    transform: skewX(-5deg);
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

.lightSpeedIn {
  -webkit-animation-name: lightSpeedIn;
  animation-name: lightSpeedIn;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

@-webkit-keyframes lightSpeedOut {
  from {
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(100%, 0, 0) skewX(30deg);
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
}

@keyframes lightSpeedOut {
  from {
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(100%, 0, 0) skewX(30deg);
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
}

.lightSpeedOut {
  -webkit-animation-name: lightSpeedOut;
  animation-name: lightSpeedOut;
  -webkit-animation-timing-function: ease-in;
  animation-timing-function: ease-in;
}

@-webkit-keyframes rotateIn {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, -200deg);
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes rotateIn {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, -200deg);
    transform: rotate3d(0, 0, 1, -200deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

.rotateIn {
  -webkit-animation-name: rotateIn;
  animation-name: rotateIn;
}

@-webkit-keyframes rotateInDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes rotateInDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

.rotateInDownLeft {
  -webkit-animation-name: rotateInDownLeft;
  animation-name: rotateInDownLeft;
}

@-webkit-keyframes rotateInDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes rotateInDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

.rotateInDownRight {
  -webkit-animation-name: rotateInDownRight;
  animation-name: rotateInDownRight;
}

@-webkit-keyframes rotateInUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes rotateInUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

.rotateInUpLeft {
  -webkit-animation-name: rotateInUpLeft;
  animation-name: rotateInUpLeft;
}

@-webkit-keyframes rotateInUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -90deg);
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

@keyframes rotateInUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -90deg);
    transform: rotate3d(0, 0, 1, -90deg);
    opacity: 0;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

.rotateInUpRight {
  -webkit-animation-name: rotateInUpRight;
  animation-name: rotateInUpRight;
}

@-webkit-keyframes rotateOut {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, 200deg);
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0;
  }
}

@keyframes rotateOut {
  from {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate3d(0, 0, 1, 200deg);
    transform: rotate3d(0, 0, 1, 200deg);
    opacity: 0;
  }
}

.rotateOut {
  -webkit-animation-name: rotateOut;
  animation-name: rotateOut;
}

@-webkit-keyframes rotateOutDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }
}

@keyframes rotateOutDownLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    transform: rotate3d(0, 0, 1, 45deg);
    opacity: 0;
  }
}

.rotateOutDownLeft {
  -webkit-animation-name: rotateOutDownLeft;
  animation-name: rotateOutDownLeft;
}

@-webkit-keyframes rotateOutDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

@keyframes rotateOutDownRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

.rotateOutDownRight {
  -webkit-animation-name: rotateOutDownRight;
  animation-name: rotateOutDownRight;
}

@-webkit-keyframes rotateOutUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

@keyframes rotateOutUpLeft {
  from {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    transform: rotate3d(0, 0, 1, -45deg);
    opacity: 0;
  }
}

.rotateOutUpLeft {
  -webkit-animation-name: rotateOutUpLeft;
  animation-name: rotateOutUpLeft;
}

@-webkit-keyframes rotateOutUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 90deg);
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0;
  }
}

@keyframes rotateOutUpRight {
  from {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }

  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate3d(0, 0, 1, 90deg);
    transform: rotate3d(0, 0, 1, 90deg);
    opacity: 0;
  }
}

.rotateOutUpRight {
  -webkit-animation-name: rotateOutUpRight;
  animation-name: rotateOutUpRight;
}

@-webkit-keyframes hinge {
  0% {
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }

  20%,
  60% {
    -webkit-transform: rotate3d(0, 0, 1, 80deg);
    transform: rotate3d(0, 0, 1, 80deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }

  40%,
  80% {
    -webkit-transform: rotate3d(0, 0, 1, 60deg);
    transform: rotate3d(0, 0, 1, 60deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(0, 700px, 0);
    transform: translate3d(0, 700px, 0);
    opacity: 0;
  }
}

@keyframes hinge {
  0% {
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }

  20%,
  60% {
    -webkit-transform: rotate3d(0, 0, 1, 80deg);
    transform: rotate3d(0, 0, 1, 80deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }

  40%,
  80% {
    -webkit-transform: rotate3d(0, 0, 1, 60deg);
    transform: rotate3d(0, 0, 1, 60deg);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1;
  }

  to {
    -webkit-transform: translate3d(0, 700px, 0);
    transform: translate3d(0, 700px, 0);
    opacity: 0;
  }
}

.hinge {
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-name: hinge;
  animation-name: hinge;
}

@-webkit-keyframes jackInTheBox {
  from {
    opacity: 0;
    -webkit-transform: scale(0.1) rotate(30deg);
    transform: scale(0.1) rotate(30deg);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
  }

  50% {
    -webkit-transform: rotate(-10deg);
    transform: rotate(-10deg);
  }

  70% {
    -webkit-transform: rotate(3deg);
    transform: rotate(3deg);
  }

  to {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

@keyframes jackInTheBox {
  from {
    opacity: 0;
    -webkit-transform: scale(0.1) rotate(30deg);
    transform: scale(0.1) rotate(30deg);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
  }

  50% {
    -webkit-transform: rotate(-10deg);
    transform: rotate(-10deg);
  }

  70% {
    -webkit-transform: rotate(3deg);
    transform: rotate(3deg);
  }

  to {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}

.jackInTheBox {
  -webkit-animation-name: jackInTheBox;
  animation-name: jackInTheBox;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@-webkit-keyframes rollIn {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes rollIn {
  from {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
  }

  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.rollIn {
  -webkit-animation-name: rollIn;
  animation-name: rollIn;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */

@-webkit-keyframes rollOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
  }
}

@keyframes rollOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
  }
}

.rollOut {
  -webkit-animation-name: rollOut;
  animation-name: rollOut;
}

@-webkit-keyframes zoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }

  50% {
    opacity: 1;
  }
}

@keyframes zoomIn {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }

  50% {
    opacity: 1;
  }
}

.zoomIn {
  -webkit-animation-name: zoomIn;
  animation-name: zoomIn;
}

@-webkit-keyframes zoomInDown {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

@keyframes zoomInDown {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

.zoomInDown {
  -webkit-animation-name: zoomInDown;
  animation-name: zoomInDown;
}

@-webkit-keyframes zoomInLeft {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

@keyframes zoomInLeft {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

.zoomInLeft {
  -webkit-animation-name: zoomInLeft;
  animation-name: zoomInLeft;
}

@-webkit-keyframes zoomInRight {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

@keyframes zoomInRight {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

.zoomInRight {
  -webkit-animation-name: zoomInRight;
  animation-name: zoomInRight;
}

@-webkit-keyframes zoomInUp {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

@keyframes zoomInUp {
  from {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  60% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

.zoomInUp {
  -webkit-animation-name: zoomInUp;
  animation-name: zoomInUp;
}

@-webkit-keyframes zoomOut {
  from {
    opacity: 1;
  }

  50% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }

  to {
    opacity: 0;
  }
}

@keyframes zoomOut {
  from {
    opacity: 1;
  }

  50% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }

  to {
    opacity: 0;
  }
}

.zoomOut {
  -webkit-animation-name: zoomOut;
  animation-name: zoomOut;
}

@-webkit-keyframes zoomOutDown {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

@keyframes zoomOutDown {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

.zoomOutDown {
  -webkit-animation-name: zoomOutDown;
  animation-name: zoomOutDown;
}

@-webkit-keyframes zoomOutLeft {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(-2000px, 0, 0);
    transform: scale(0.1) translate3d(-2000px, 0, 0);
    -webkit-transform-origin: left center;
    transform-origin: left center;
  }
}

@keyframes zoomOutLeft {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(-2000px, 0, 0);
    transform: scale(0.1) translate3d(-2000px, 0, 0);
    -webkit-transform-origin: left center;
    transform-origin: left center;
  }
}

.zoomOutLeft {
  -webkit-animation-name: zoomOutLeft;
  animation-name: zoomOutLeft;
}

@-webkit-keyframes zoomOutRight {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(2000px, 0, 0);
    transform: scale(0.1) translate3d(2000px, 0, 0);
    -webkit-transform-origin: right center;
    transform-origin: right center;
  }
}

@keyframes zoomOutRight {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
  }

  to {
    opacity: 0;
    -webkit-transform: scale(0.1) translate3d(2000px, 0, 0);
    transform: scale(0.1) translate3d(2000px, 0, 0);
    -webkit-transform-origin: right center;
    transform-origin: right center;
  }
}

.zoomOutRight {
  -webkit-animation-name: zoomOutRight;
  animation-name: zoomOutRight;
}

@-webkit-keyframes zoomOutUp {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

@keyframes zoomOutUp {
  40% {
    opacity: 1;
    -webkit-transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }

  to {
    opacity: 0;
    -webkit-transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}

.zoomOutUp {
  -webkit-animation-name: zoomOutUp;
  animation-name: zoomOutUp;
}

@-webkit-keyframes slideInDown {
  from {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInDown {
  from {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.slideInDown {
  -webkit-animation-name: slideInDown;
  animation-name: slideInDown;
}

@-webkit-keyframes slideInLeft {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInLeft {
  from {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.slideInLeft {
  -webkit-animation-name: slideInLeft;
  animation-name: slideInLeft;
}

@-webkit-keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInRight {
  from {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.slideInRight {
  -webkit-animation-name: slideInRight;
  animation-name: slideInRight;
}

@-webkit-keyframes slideInUp {
  from {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes slideInUp {
  from {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }

  to {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}

.slideInUp {
  -webkit-animation-name: slideInUp;
  animation-name: slideInUp;
}

@-webkit-keyframes slideOutDown {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}

@keyframes slideOutDown {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}

.slideOutDown {
  -webkit-animation-name: slideOutDown;
  animation-name: slideOutDown;
}

@-webkit-keyframes slideOutLeft {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}

@keyframes slideOutLeft {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}

.slideOutLeft {
  -webkit-animation-name: slideOutLeft;
  animation-name: slideOutLeft;
}

@-webkit-keyframes slideOutRight {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

@keyframes slideOutRight {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}

.slideOutRight {
  -webkit-animation-name: slideOutRight;
  animation-name: slideOutRight;
}

@-webkit-keyframes slideOutUp {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}

@keyframes slideOutUp {
  from {
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }

  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}

.slideOutUp {
  -webkit-animation-name: slideOutUp;
  animation-name: slideOutUp;
}

@keyframes rotate {
  from {
    transform: rotate(360deg);
    opacity: 0;
  scale(0.15);
  }
  to {
    transform: rotate(-360deg);
    opacity: 1;
  scale(1);
  }
}

.rotate {
  -webkit-animation-name: rotate;
  animation-name: rotate;
}

@keyframes rotateOut {
  from {
    transform: rotate(-360deg);
    opacity: 1;
  scale(1);
  }
  to {
    transform: rotate(360deg);
    opacity: 0;
  scale(0.15);
  }
}

.rotateOut {
  -webkit-animation-name: rotateOut;
  animation-name: rotateOut;
}

@keyframes rotateInX {
  from {
    transform: perspective(800px) rotateY(180deg) translateZ(1px);
    opacity:0;
  }
  30% {
    transform: perspective(800px) rotateY(90deg) translateZ(1px);
  }
  to {
    transform: perspective(800px) rotateY(0deg) translateZ(0px);
    opacity:1;
  }
}

.rotateInX {
  -webkit-animation-name: rotateInX;
  animation-name: rotateInX;
}

@keyframes rotateOutX {
  from {
    transform: perspective(800px) rotateY(0deg) translateZ(0px);
    opacity:1;
  }
  30% {
    transform: perspective(800px) rotateY(90deg) translateZ(1px);
    opacity:0.5;
  }
  to {
    transform: perspective(800px) rotateY(180deg) translateZ(1px);
    opacity:0;
  }
}

.rotateOutX {
  -webkit-animation-name: rotateOutX;
  animation-name: rotateOutX;
}

@keyframes rotateInY {
  from {
    transform: perspective(800px) rotateX(-120deg) translateX(0px);
    opacity:0;
  }
  30% {
    transform: perspective(800px) rotateX(-90deg) translateZ(1px);
  }
  to {
    transform: perspective(800px) rotateX(0deg) translateZ(1px);
    opacity:1;
  }
}

.rotateInY {
  -webkit-animation-name: rotateInY;
  animation-name: rotateInY;
}

@keyframes rotateOutY {
  from {
    transform: perspective(800px) rotateX(0deg) translateX(0px);
    opacity: 1;
  }
  30% {
    transform: perspective(800px) rotateX(-90deg) translateZ(1px);
  }
  to {
    transform: perspective(800px) rotateX(-120deg) translateZ(1px);
    opacity: 0;
  }
}

.rotateOutY {
  -webkit-animation-name: rotateOutY;
  animation-name: rotateOutY;
}