@charset "UTF-8";
/*Owl slider*/
/*@use 'owl/owl.carousel.scss';*/
/*@use 'owl/owl.theme.scss';*/
/* Main setup */
/**/
/*Variables*/
/*--------------------------------------------------*/
/*

font-family: Switzer-Thin;
font-family: Switzer-ThinItalic;
font-family: Switzer-Extralight;
font-family: Switzer-ExtralightItalic;
font-family: Switzer-Light;
font-family: Switzer-LightItalic;
font-family: Switzer-Regular;
font-family: Switzer-Italic;
font-family: Switzer-Medium;
font-family: Switzer-MediumItalic;
font-family: Switzer-Semibold;
font-family: Switzer-SemiboldItalic;
font-family: Switzer-Bold;
font-family: Switzer-BoldItalic;
font-family: Switzer-Extrabold;
font-family: Switzer-ExtraboldItalic;
font-family: Switzer-Black;
font-family: Switzer-BlackItalic;
font-family: Switzer-Variable;
font-family: Switzer-VariableItalic;

*/
:root {
  --main-font-size: 19px;
  /*--html-bg: #fff;*/
  --color-bg: #f5f0f8;
  /*--color-bg: #f6f5f8;*/
  /*--color-bg: #f0ebf5;*/
  --color-text: #111;
  --menu-text: #fff;
  --page-text: 3rem;
  /*--layout-lines: #ffb800;*/
  /*--layout-lines: #ff729f;*/
  /*--layout-lines: #ff90b3;*/
  --layout-lines: #ba55d3;
  /*--layout-lines: #e9df00;*/
  --default-lines: 1.2;
  --headline-lines: .9;
  --body-font: Switzer;
  --headline-font: Switzer;
  --primary: #ba55d3;
  --text-light: #fff;
  --overlay-bg: #ba55d3;
  --brand: #ba55d3;
  /*--brand: #C77DFF;*/
  --menu-icon: #111;
  --button-border: var(--brand);
  /*--button-text: #111;*/
  --button-text: #fff;
  --button-text-secondary: #111;
  --button-text-light: #111;
  /*--button-shadow-rgb: rgb(186, 85, 211);*/
  --button-shadow-rgba-low: rgba(186, 85, 211, .3);
  --button-shadow-rgba-high: rgba(186, 85, 211, .9);
  --seoncary-button: #d9d9d9;
  --form-labels: #111;
  --form-box: #717171;
  --form-input: #111;
  --form-bg: #fff;
  --highlighter-bg: rgba(252, 244, 3, .5);
  --highlighter-text: #111;
  --mark-tag-text: #111;
  --blockquote-text: #777;
  --blockquote-box: #b0b0b0;
  --board-border: #e1e8ed;
  --board-bg: #faf8fc;
  --board-text: #14171a;
  --board-date: #657786;
  --board-headerline: #f0f0f0;
  /*--board-link: #1da1f2;*/
  --board-link: #0077bf;
  --footer-end-bg: #515151;
  --footer-end-text: #eee;
  --a-link: #0077bf;
  --a-link-hover: #0077bf;
  --banner-text: #111;
  --banner-link: #111;
  --banner-bg: #fcf403;
  --article-list-hover-bg: rgba(255, 255, 255, .4);
  --logo-area-bg: #f5e6f8;
  --meny-overlay-bg: var(--brand);
  --linktree-hover-text: #111;
  --linktree-card-bg: #fff;
  --linktree-border: #b0b0b0;
  --linktree-text: #111;
}

[data-theme=dark] {
  /*--html-bg: #222;*/
  --color-bg: #222;
  --color-text: #eaeaea;
  /*--menu-text: #111;*/
  --menu-text: #fff;
  --layout-lines: #e9df00;
  --brand: #c77dff;
  /*--menu-icon: var(--brand);*/
  /*--menu-icon: #fff;*/
  --menu-icon: #1da1f2;
  --button-border: #bd77f2;
  /*--button-shadow-rgb: rgb(189, 119, 242);*/
  --button-shadow-rgba-low: rgba(189, 119, 242, .3);
  --button-shadow-rgba-high: rgba(189, 119, 242, .7);
  /*--button-text: #fff;*/
  --button-text: #111;
  --button-text-secondary: #111;
  --button-text-light: #fff;
  --seoncary-button: #888;
  --form-labels: #fff;
  --form-box: #9b9b9b;
  --form-input: #fff;
  --form-bg: #111;
  --highlighter-bg: rgba(252, 244, 3, .85);
  --highlighter-text: #111;
  --mark-tag-text: #111;
  --blockquote-text: #777;
  --blockquote-box: #777;
  --board-border: #333;
  --board-bg: #1a1a1a;
  --board-text: #e1e8ed;
  --board-date: #aaa;
  --board-headerline: #2a2a2a;
  --board-link: #1da1f2;
  --footer-end-bg: #111;
  --footer-end-text: #999;
  --a-link: #1da1f2;
  --a-link-hover: #1da1f2;
  --banner-text: #111;
  --banner-link: #111;
  --banner-bg: #fcf403;
  --article-list-hover-bg: rgba(255, 255, 255, .1);
  --logo-area-bg: #cfcfcf;
  /*--meny-overlay-bg: var(--brand);*/
  --meny-overlay-bg: #ba55d3;
  --linktree-hover-text: #111;
  --linktree-card-bg: #111;
  --linktree-border: #333;
  --linktree-text: #fff;
}

.theme-changing * {
  transition: none !important;
}

html,
body {
  -webkit-font-smoothing: antialiased;
}

body {
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--main-font-size);
  font-family: var(--body-font);
  line-height: var(--default-lines);
}

.page-wrapper {
  width: 100%;
}

figure img {
  border-radius: 20px;
}

/*.wrapper {
  display: flex;
  align-items: center;
}

button {
  background: var(--btn-bg, #555);
}*/
/*.red-line {
  border: solid 2px;
  border-color: var(--layout-lines, red);
}*/
.theme-toggle {
  /*display: inline-flex;*/
  /*font: inherit;*/
  cursor: pointer;
  /*align-items: center;*/
  /*gap: .5rem;*/
}

.theme-icon {
  width: 1.25rem;
  height: 1.25rem;
}

/* Default = light mode → show moon */
.icon-sun {
  display: none;
}

/* Dark mode active → show sun */
[data-theme=dark] .icon-moon {
  display: none;
}

[data-theme=dark] .icon-sun {
  display: inline;
}

.theme-icon {
  transition: transform 0.2s ease, opacity 0.2s ease;
}

[data-theme=dark] .theme-icon {
  opacity: 0.85;
}

/* ===== Minimal Reset ===== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

.clearfix::after {
  display: table;
  clear: both;
  content: "";
}

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

.container {
  margin-right: auto;
  margin-left: auto;
  padding-right: 15px;
  padding-left: 15px;
}

@media (min-width: 768px) {
  .container {
    width: 750px;
  }
}
@media (min-width: 992px) {
  .container {
    width: 970px;
  }
}
@media (min-width: 1200px) {
  .container {
    width: 1170px;
  }
}
.container-fluid {
  margin-right: auto;
  margin-left: auto;
  padding-right: 15px;
  padding-left: 15px;
}

.row {
  margin-right: -15px;
  margin-left: -15px;
}

.row-no-gutters {
  margin-right: 0;
  margin-left: 0;
}

.row-no-gutters [class*=col-] {
  padding-right: 0;
  padding-left: 0;
}

.col-xs-1,
.col-sm-1,
.col-md-1,
.col-lg-1,
.col-xs-2,
.col-sm-2,
.col-md-2,
.col-lg-2,
.col-xs-3,
.col-sm-3,
.col-md-3,
.col-lg-3,
.col-xs-4,
.col-sm-4,
.col-md-4,
.col-lg-4,
.col-xs-5,
.col-sm-5,
.col-md-5,
.col-lg-5,
.col-xs-6,
.col-sm-6,
.col-md-6,
.col-lg-6,
.col-xs-7,
.col-sm-7,
.col-md-7,
.col-lg-7,
.col-xs-8,
.col-sm-8,
.col-md-8,
.col-lg-8,
.col-xs-9,
.col-sm-9,
.col-md-9,
.col-lg-9,
.col-xs-10,
.col-sm-10,
.col-md-10,
.col-lg-10,
.col-xs-11,
.col-sm-11,
.col-md-11,
.col-lg-11,
.col-xs-12,
.col-sm-12,
.col-md-12,
.col-lg-12 {
  position: relative;
  padding-right: 15px;
  padding-left: 15px;
  min-height: 1px;
}

.col-xs-1,
.col-xs-2,
.col-xs-3,
.col-xs-4,
.col-xs-5,
.col-xs-6,
.col-xs-7,
.col-xs-8,
.col-xs-9,
.col-xs-10,
.col-xs-11,
.col-xs-12 {
  float: left;
}

.col-xs-12 {
  width: 100%;
}

.col-xs-11 {
  width: 91.66666667%;
}

.col-xs-10 {
  width: 83.33333333%;
}

.col-xs-9 {
  width: 75%;
}

.col-xs-8 {
  width: 66.66666667%;
}

.col-xs-7 {
  width: 58.33333333%;
}

.col-xs-6 {
  width: 50%;
}

.col-xs-5 {
  width: 41.66666667%;
}

.col-xs-4 {
  width: 33.33333333%;
}

.col-xs-3 {
  width: 25%;
}

.col-xs-2 {
  width: 16.66666667%;
}

.col-xs-1 {
  width: 8.33333333%;
}

.col-xs-pull-12 {
  right: 100%;
}

.col-xs-pull-11 {
  right: 91.66666667%;
}

.col-xs-pull-10 {
  right: 83.33333333%;
}

.col-xs-pull-9 {
  right: 75%;
}

.col-xs-pull-8 {
  right: 66.66666667%;
}

.col-xs-pull-7 {
  right: 58.33333333%;
}

.col-xs-pull-6 {
  right: 50%;
}

.col-xs-pull-5 {
  right: 41.66666667%;
}

.col-xs-pull-4 {
  right: 33.33333333%;
}

.col-xs-pull-3 {
  right: 25%;
}

.col-xs-pull-2 {
  right: 16.66666667%;
}

.col-xs-pull-1 {
  right: 8.33333333%;
}

.col-xs-pull-0 {
  right: auto;
}

.col-xs-push-12 {
  left: 100%;
}

.col-xs-push-11 {
  left: 91.66666667%;
}

.col-xs-push-10 {
  left: 83.33333333%;
}

.col-xs-push-9 {
  left: 75%;
}

.col-xs-push-8 {
  left: 66.66666667%;
}

.col-xs-push-7 {
  left: 58.33333333%;
}

.col-xs-push-6 {
  left: 50%;
}

.col-xs-push-5 {
  left: 41.66666667%;
}

.col-xs-push-4 {
  left: 33.33333333%;
}

.col-xs-push-3 {
  left: 25%;
}

.col-xs-push-2 {
  left: 16.66666667%;
}

.col-xs-push-1 {
  left: 8.33333333%;
}

.col-xs-push-0 {
  left: auto;
}

.col-xs-offset-12 {
  margin-left: 100%;
}

.col-xs-offset-11 {
  margin-left: 91.66666667%;
}

.col-xs-offset-10 {
  margin-left: 83.33333333%;
}

.col-xs-offset-9 {
  margin-left: 75%;
}

.col-xs-offset-8 {
  margin-left: 66.66666667%;
}

.col-xs-offset-7 {
  margin-left: 58.33333333%;
}

.col-xs-offset-6 {
  margin-left: 50%;
}

.col-xs-offset-5 {
  margin-left: 41.66666667%;
}

.col-xs-offset-4 {
  margin-left: 33.33333333%;
}

.col-xs-offset-3 {
  margin-left: 25%;
}

.col-xs-offset-2 {
  margin-left: 16.66666667%;
}

.col-xs-offset-1 {
  margin-left: 8.33333333%;
}

.col-xs-offset-0 {
  margin-left: 0;
}

@media (min-width: 768px) {
  .col-sm-1,
  .col-sm-2,
  .col-sm-3,
  .col-sm-4,
  .col-sm-5,
  .col-sm-6,
  .col-sm-7,
  .col-sm-8,
  .col-sm-9,
  .col-sm-10,
  .col-sm-11,
  .col-sm-12 {
    float: left;
  }
  .col-sm-12 {
    width: 100%;
  }
  .col-sm-11 {
    width: 91.66666667%;
  }
  .col-sm-10 {
    width: 83.33333333%;
  }
  .col-sm-9 {
    width: 75%;
  }
  .col-sm-8 {
    width: 66.66666667%;
  }
  .col-sm-7 {
    width: 58.33333333%;
  }
  .col-sm-6 {
    width: 50%;
  }
  .col-sm-5 {
    width: 41.66666667%;
  }
  .col-sm-4 {
    width: 33.33333333%;
  }
  .col-sm-3 {
    width: 25%;
  }
  .col-sm-2 {
    width: 16.66666667%;
  }
  .col-sm-1 {
    width: 8.33333333%;
  }
  .col-sm-pull-12 {
    right: 100%;
  }
  .col-sm-pull-11 {
    right: 91.66666667%;
  }
  .col-sm-pull-10 {
    right: 83.33333333%;
  }
  .col-sm-pull-9 {
    right: 75%;
  }
  .col-sm-pull-8 {
    right: 66.66666667%;
  }
  .col-sm-pull-7 {
    right: 58.33333333%;
  }
  .col-sm-pull-6 {
    right: 50%;
  }
  .col-sm-pull-5 {
    right: 41.66666667%;
  }
  .col-sm-pull-4 {
    right: 33.33333333%;
  }
  .col-sm-pull-3 {
    right: 25%;
  }
  .col-sm-pull-2 {
    right: 16.66666667%;
  }
  .col-sm-pull-1 {
    right: 8.33333333%;
  }
  .col-sm-pull-0 {
    right: auto;
  }
  .col-sm-push-12 {
    left: 100%;
  }
  .col-sm-push-11 {
    left: 91.66666667%;
  }
  .col-sm-push-10 {
    left: 83.33333333%;
  }
  .col-sm-push-9 {
    left: 75%;
  }
  .col-sm-push-8 {
    left: 66.66666667%;
  }
  .col-sm-push-7 {
    left: 58.33333333%;
  }
  .col-sm-push-6 {
    left: 50%;
  }
  .col-sm-push-5 {
    left: 41.66666667%;
  }
  .col-sm-push-4 {
    left: 33.33333333%;
  }
  .col-sm-push-3 {
    left: 25%;
  }
  .col-sm-push-2 {
    left: 16.66666667%;
  }
  .col-sm-push-1 {
    left: 8.33333333%;
  }
  .col-sm-push-0 {
    left: auto;
  }
  .col-sm-offset-12 {
    margin-left: 100%;
  }
  .col-sm-offset-11 {
    margin-left: 91.66666667%;
  }
  .col-sm-offset-10 {
    margin-left: 83.33333333%;
  }
  .col-sm-offset-9 {
    margin-left: 75%;
  }
  .col-sm-offset-8 {
    margin-left: 66.66666667%;
  }
  .col-sm-offset-7 {
    margin-left: 58.33333333%;
  }
  .col-sm-offset-6 {
    margin-left: 50%;
  }
  .col-sm-offset-5 {
    margin-left: 41.66666667%;
  }
  .col-sm-offset-4 {
    margin-left: 33.33333333%;
  }
  .col-sm-offset-3 {
    margin-left: 25%;
  }
  .col-sm-offset-2 {
    margin-left: 16.66666667%;
  }
  .col-sm-offset-1 {
    margin-left: 8.33333333%;
  }
  .col-sm-offset-0 {
    margin-left: 0;
  }
}
@media (min-width: 992px) {
  .col-md-1,
  .col-md-2,
  .col-md-3,
  .col-md-4,
  .col-md-5,
  .col-md-6,
  .col-md-7,
  .col-md-8,
  .col-md-9,
  .col-md-10,
  .col-md-11,
  .col-md-12 {
    float: left;
  }
  .col-md-12 {
    width: 100%;
  }
  .col-md-11 {
    width: 91.66666667%;
  }
  .col-md-10 {
    width: 83.33333333%;
  }
  .col-md-9 {
    width: 75%;
  }
  .col-md-8 {
    width: 66.66666667%;
  }
  .col-md-7 {
    width: 58.33333333%;
  }
  .col-md-6 {
    width: 50%;
  }
  .col-md-5 {
    width: 41.66666667%;
  }
  .col-md-4 {
    width: 33.33333333%;
  }
  .col-md-3 {
    width: 25%;
  }
  .col-md-2 {
    width: 16.66666667%;
  }
  .col-md-1 {
    width: 8.33333333%;
  }
  .col-md-pull-12 {
    right: 100%;
  }
  .col-md-pull-11 {
    right: 91.66666667%;
  }
  .col-md-pull-10 {
    right: 83.33333333%;
  }
  .col-md-pull-9 {
    right: 75%;
  }
  .col-md-pull-8 {
    right: 66.66666667%;
  }
  .col-md-pull-7 {
    right: 58.33333333%;
  }
  .col-md-pull-6 {
    right: 50%;
  }
  .col-md-pull-5 {
    right: 41.66666667%;
  }
  .col-md-pull-4 {
    right: 33.33333333%;
  }
  .col-md-pull-3 {
    right: 25%;
  }
  .col-md-pull-2 {
    right: 16.66666667%;
  }
  .col-md-pull-1 {
    right: 8.33333333%;
  }
  .col-md-pull-0 {
    right: auto;
  }
  .col-md-push-12 {
    left: 100%;
  }
  .col-md-push-11 {
    left: 91.66666667%;
  }
  .col-md-push-10 {
    left: 83.33333333%;
  }
  .col-md-push-9 {
    left: 75%;
  }
  .col-md-push-8 {
    left: 66.66666667%;
  }
  .col-md-push-7 {
    left: 58.33333333%;
  }
  .col-md-push-6 {
    left: 50%;
  }
  .col-md-push-5 {
    left: 41.66666667%;
  }
  .col-md-push-4 {
    left: 33.33333333%;
  }
  .col-md-push-3 {
    left: 25%;
  }
  .col-md-push-2 {
    left: 16.66666667%;
  }
  .col-md-push-1 {
    left: 8.33333333%;
  }
  .col-md-push-0 {
    left: auto;
  }
  .col-md-offset-12 {
    margin-left: 100%;
  }
  .col-md-offset-11 {
    margin-left: 91.66666667%;
  }
  .col-md-offset-10 {
    margin-left: 83.33333333%;
  }
  .col-md-offset-9 {
    margin-left: 75%;
  }
  .col-md-offset-8 {
    margin-left: 66.66666667%;
  }
  .col-md-offset-7 {
    margin-left: 58.33333333%;
  }
  .col-md-offset-6 {
    margin-left: 50%;
  }
  .col-md-offset-5 {
    margin-left: 41.66666667%;
  }
  .col-md-offset-4 {
    margin-left: 33.33333333%;
  }
  .col-md-offset-3 {
    margin-left: 25%;
  }
  .col-md-offset-2 {
    margin-left: 16.66666667%;
  }
  .col-md-offset-1 {
    margin-left: 8.33333333%;
  }
  .col-md-offset-0 {
    margin-left: 0;
  }
}
@media (min-width: 1200px) {
  .col-lg-1,
  .col-lg-2,
  .col-lg-3,
  .col-lg-4,
  .col-lg-5,
  .col-lg-6,
  .col-lg-7,
  .col-lg-8,
  .col-lg-9,
  .col-lg-10,
  .col-lg-11,
  .col-lg-12 {
    float: left;
  }
  .col-lg-12 {
    width: 100%;
  }
  .col-lg-11 {
    width: 91.66666667%;
  }
  .col-lg-10 {
    width: 83.33333333%;
  }
  .col-lg-9 {
    width: 75%;
  }
  .col-lg-8 {
    width: 66.66666667%;
  }
  .col-lg-7 {
    width: 58.33333333%;
  }
  .col-lg-6 {
    width: 50%;
  }
  .col-lg-5 {
    width: 41.66666667%;
  }
  .col-lg-4 {
    width: 33.33333333%;
  }
  .col-lg-3 {
    width: 25%;
  }
  .col-lg-2 {
    width: 16.66666667%;
  }
  .col-lg-1 {
    width: 8.33333333%;
  }
  .col-lg-pull-12 {
    right: 100%;
  }
  .col-lg-pull-11 {
    right: 91.66666667%;
  }
  .col-lg-pull-10 {
    right: 83.33333333%;
  }
  .col-lg-pull-9 {
    right: 75%;
  }
  .col-lg-pull-8 {
    right: 66.66666667%;
  }
  .col-lg-pull-7 {
    right: 58.33333333%;
  }
  .col-lg-pull-6 {
    right: 50%;
  }
  .col-lg-pull-5 {
    right: 41.66666667%;
  }
  .col-lg-pull-4 {
    right: 33.33333333%;
  }
  .col-lg-pull-3 {
    right: 25%;
  }
  .col-lg-pull-2 {
    right: 16.66666667%;
  }
  .col-lg-pull-1 {
    right: 8.33333333%;
  }
  .col-lg-pull-0 {
    right: auto;
  }
  .col-lg-push-12 {
    left: 100%;
  }
  .col-lg-push-11 {
    left: 91.66666667%;
  }
  .col-lg-push-10 {
    left: 83.33333333%;
  }
  .col-lg-push-9 {
    left: 75%;
  }
  .col-lg-push-8 {
    left: 66.66666667%;
  }
  .col-lg-push-7 {
    left: 58.33333333%;
  }
  .col-lg-push-6 {
    left: 50%;
  }
  .col-lg-push-5 {
    left: 41.66666667%;
  }
  .col-lg-push-4 {
    left: 33.33333333%;
  }
  .col-lg-push-3 {
    left: 25%;
  }
  .col-lg-push-2 {
    left: 16.66666667%;
  }
  .col-lg-push-1 {
    left: 8.33333333%;
  }
  .col-lg-push-0 {
    left: auto;
  }
  .col-lg-offset-12 {
    margin-left: 100%;
  }
  .col-lg-offset-11 {
    margin-left: 91.66666667%;
  }
  .col-lg-offset-10 {
    margin-left: 83.33333333%;
  }
  .col-lg-offset-9 {
    margin-left: 75%;
  }
  .col-lg-offset-8 {
    margin-left: 66.66666667%;
  }
  .col-lg-offset-7 {
    margin-left: 58.33333333%;
  }
  .col-lg-offset-6 {
    margin-left: 50%;
  }
  .col-lg-offset-5 {
    margin-left: 41.66666667%;
  }
  .col-lg-offset-4 {
    margin-left: 33.33333333%;
  }
  .col-lg-offset-3 {
    margin-left: 25%;
  }
  .col-lg-offset-2 {
    margin-left: 16.66666667%;
  }
  .col-lg-offset-1 {
    margin-left: 8.33333333%;
  }
  .col-lg-offset-0 {
    margin-left: 0;
  }
}
/* =========================================================
   Bootstrap v3–inspired vertical spacing utilities (6× base)
   Scale: 30 / 60 / 90 / 180 / 270
   ========================================================= */
/* Core vertical spacing (top + bottom) */
.vspace-xs {
  margin-top: 30px;
  margin-bottom: 30px;
}

.vspace-sm {
  margin-top: 60px;
  margin-bottom: 60px;
}

.vspace-md {
  margin-top: 90px;
  margin-bottom: 90px;
} /* default */
.vspace-lg {
  margin-top: 180px;
  margin-bottom: 180px;
}

.vspace-xl {
  margin-top: 270px;
  margin-bottom: 270px;
}

/* Margin top helpers */
.mt-xs {
  margin-top: 30px;
}

.mt-sm {
  margin-top: 60px;
}

.mt-md {
  margin-top: 90px;
}

.mt-lg {
  margin-top: 180px;
}

.mt-xl {
  margin-top: 270px;
}

/* Margin bottom helpers */
.mb-xs {
  margin-bottom: 30px;
}

.mb-sm {
  margin-bottom: 60px;
}

.mb-md {
  margin-bottom: 90px;
}

.mb-lg {
  margin-bottom: 180px;
}

.mb-xl {
  margin-bottom: 270px;
}

/* Row-safe spacing (use on .row elements) */
.row-space-xs {
  margin-bottom: 30px;
}

.row-space-sm {
  margin-bottom: 60px;
}

.row-space {
  margin-bottom: 90px;
}

.row-space-lg {
  margin-bottom: 180px;
}

/* Reset helpers */
.no-margin {
  margin: 0 !important;
}

.no-margin-top {
  margin-top: 0 !important;
}

.no-margin-bottom {
  margin-bottom: 0 !important;
}

.clearfix:before,
.clearfix:after {
  display: table;
  content: " ";
}

.clearfix:after {
  clear: both;
}

.center-block {
  display: block;
  margin-right: auto;
  margin-left: auto;
}

.pull-left {
  float: left !important;
}

.pull-right {
  float: right !important;
}

.hidden {
  display: none !important;
}

.visible-xs,
.visible-sm,
.visible-md,
.visible-lg {
  display: none !important;
}

.visible-xs-block,
.visible-xs-inline,
.visible-xs-inline-block,
.visible-sm-block,
.visible-sm-inline,
.visible-sm-inline-block,
.visible-md-block,
.visible-md-inline,
.visible-md-inline-block,
.visible-lg-block,
.visible-lg-inline,
.visible-lg-inline-block {
  display: none !important;
}

@media (max-width: 767px) {
  .visible-xs {
    display: block !important;
  }
  table.visible-xs {
    display: table !important;
  }
  tr.visible-xs {
    display: table-row !important;
  }
  th.visible-xs,
  td.visible-xs {
    display: table-cell !important;
  }
}
@media (max-width: 767px) {
  .visible-xs-block {
    display: block !important;
  }
}
@media (max-width: 767px) {
  .visible-xs-inline {
    display: inline !important;
  }
}
@media (max-width: 767px) {
  .visible-xs-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm {
    display: block !important;
  }
  table.visible-sm {
    display: table !important;
  }
  tr.visible-sm {
    display: table-row !important;
  }
  th.visible-sm,
  td.visible-sm {
    display: table-cell !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm-block {
    display: block !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm-inline {
    display: inline !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .visible-md {
    display: block !important;
  }
  table.visible-md {
    display: table !important;
  }
  tr.visible-md {
    display: table-row !important;
  }
  th.visible-md,
  td.visible-md {
    display: table-cell !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .visible-md-block {
    display: block !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .visible-md-inline {
    display: inline !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .visible-md-inline-block {
    display: inline-block !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg {
    display: block !important;
  }
  table.visible-lg {
    display: table !important;
  }
  tr.visible-lg {
    display: table-row !important;
  }
  th.visible-lg,
  td.visible-lg {
    display: table-cell !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg-block {
    display: block !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg-inline {
    display: inline !important;
  }
}
@media (min-width: 1200px) {
  .visible-lg-inline-block {
    display: inline-block !important;
  }
}
@media (max-width: 767px) {
  .hidden-xs {
    display: none !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .hidden-sm {
    display: none !important;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .hidden-md {
    display: none !important;
  }
}
@media (min-width: 1200px) {
  .hidden-lg {
    display: none !important;
  }
}
/* Regular weights */
@font-face {
  font-weight: 100;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Thin.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 100;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-ThinItalic.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 200;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Extralight.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 200;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-ExtralightItalic.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 300;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Light.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 300;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-LightItalic.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 400;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Regular.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 400;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Italic.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 500;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Medium.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 500;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-MediumItalic.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 600;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Semibold.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 600;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-SemiboldItalic.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 700;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Bold.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 700;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-BoldItalic.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 800;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Extrabold.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 800;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-ExtraboldItalic.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 900;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Black.woff2") format("woff2");
  font-display: swap;
}
@font-face {
  font-weight: 900;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-BlackItalic.woff2") format("woff2");
  font-display: swap;
}
/* Variable font (recommended) */
@font-face {
  font-weight: 100 900;
  font-style: normal;
  font-family: "Switzer";
  src: url("../fonts/Switzer-Variable.woff2") format("woff2-variations");
  font-display: swap;
}
@font-face {
  font-weight: 100 900;
  font-style: italic;
  font-family: "Switzer";
  src: url("../fonts/Switzer-VariableItalic.woff2") format("woff2-variations");
  font-display: swap;
}
/* Blockquote weights */
@font-face {
  font-weight: 700;
  font-style: normal;
  font-family: "Sentient";
  src: url("../fonts/Sentient-BoldItalic.woff2") format("woff2");
  font-display: swap;
}
#gdpr-popup {
  position: fixed;
  bottom: 10px;
  left: 50%;
  z-index: 10;
  display: none;
  /*padding: 15px;*/
  padding: 30px 30px;
  padding-bottom: 40px;
  width: 50%;
  border-radius: 5px;
  /*background: #aba89d;*/
  background: #090909;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.4);
  color: #fff;
  text-align: center;
  font-weight: 700;
  font-size: 19px;
  transform: translateX(-50%);
}

@media (max-width: 1200px) {
  #gdpr-popup {
    width: 80%;
  }
}
@media (max-width: 789px) {
  #gdpr-popup {
    width: 96%;
  }
}
#gdpr-popup p {
  color: #fff;
}

/*#gdpr-popup a {
  border-bottom: #f6eadb solid 2px;
  color: #fff;
  text-decoration: none;
  &:hover {
    text-decoration: none;
  }
}*/
/*#gdpr-popup button {
  margin-left: 10px;
  padding: 12px 60px;
  padding: 5px 10px;
  min-width: 320px;
  width: 100%;
  border: 2px solid #95cc21;
  border: none;
  border-color: #95cc21;
  border-radius: 90px;
  background: #95cc21;
  background: #00f;
  color: #1d2857;
  color: #fff;
  vertical-align: middle;
  text-decoration: none;
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 900;
  font-size: 18px;
  cursor: pointer;

  inset: 0;

  &:hover {
    border-color: #95cc21;
    background: #95cc21;
    box-shadow: 0 8px 20px 0 rgba(149,204,33,.55);
    text-decoration: none;
  }
}*/
#gdpr-popup button {
  inset: 0;
}

/* Header */
.header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 100;
  padding: 1.5rem 2rem;
  /*background: rgba(255, 255, 255, .95);*/
  /*box-shadow: 0 2px 20px rgba(0, 0, 0, .05);*/
  /*backdrop-filter: blur(10px);*/
  pointer-events: none;
}

.header-content {
  display: flex;
  float: right;
  margin: 0 auto;
  max-width: 1400px;
  justify-content: space-between;
  align-items: center;
}

/* Hamburger Button */
.menu-toggle {
  position: relative;
  z-index: 1001;
  padding: 0;
  width: 48px;
  height: 48px;
  border: none;
  background: none;
  cursor: pointer;
  transition: transform 0.3s ease;
  pointer-events: auto;
}

.menu-toggle:hover {
  transform: scale(1.1);
}

.menu-toggle:active {
  transform: scale(0.95);
}

.icon {
  display: block;
  width: 100%;
  height: 100%;
}

.hamburger-icon,
.close-icon {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.hamburger-icon {
  opacity: 1;
  transform: rotate(0deg);
}

.close-icon {
  opacity: 0;
  transform: rotate(180deg);
}

.menu-toggle.active .hamburger-icon {
  opacity: 0;
  transform: rotate(-180deg);
}

.menu-toggle.active .close-icon {
  opacity: 1;
  transform: rotate(0deg);
}

/* Overlay Menu */
.overlay-menu {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  visibility: hidden;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  width: 100%;
  height: 100vh;
  background: var(--meny-overlay-bg);
  opacity: 0;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}

.overlay-menu.active {
  visibility: visible;
  opacity: 1;
}

/* Close Button in Overlay */
.overlay-close {
  position: fixed;
  top: 1.5rem;
  right: 2rem;
  z-index: 1001;
  padding: 0;
  width: 48px;
  height: 48px;
  border: none;
  background: none;
  opacity: 0;
  cursor: pointer;
  transition: opacity 0.3s ease 0.2s, transform 0.3s ease 0.2s;
  transform: scale(0.8) rotate(-90deg);
}

.overlay-menu.active .overlay-close {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.overlay-close:hover {
  transform: scale(1.1) rotate(90deg);
}

.overlay-close:active {
  transform: scale(0.95) rotate(90deg);
}

.menu-content {
  display: flex;
  flex-direction: column;
  padding: 8rem 2rem 3rem 2rem;
  min-height: 100vh;
  justify-content: center;
}

.menu-container {
  padding-bottom: 160px;
  max-width: 700px;
  width: 100%;
}

/* Larger screens - more left padding and full-width borders */
@media (min-width: 769px) {
  .menu-content {
    padding: 8rem 4rem 3rem 6rem;
  }
}
@media (min-width: 1200px) {
  .menu-content {
    padding: 8rem 4rem 3rem 8rem;
  }
}
@media (min-width: 1400px) {
  .menu-content {
    padding: 8rem 4rem 3rem 10rem;
  }
}
.menu-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.menu-item {
  opacity: 0;
  transition: opacity 0.5s ease, transform 0.5s ease;
  transform: translateX(-30px);
}

.overlay-menu.active .menu-item {
  opacity: 1;
  transform: translateX(0);
}

.menu-item:nth-child(1) {
  transition-delay: 0.1s;
}

.menu-item:nth-child(2) {
  transition-delay: 0.15s;
}

.menu-item:nth-child(3) {
  transition-delay: 0.2s;
}

.menu-item:nth-child(4) {
  transition-delay: 0.25s;
}

.menu-item:nth-child(5) {
  transition-delay: 0.3s;
}

.menu-item:nth-child(6) {
  transition-delay: 0.35s;
}

.menu-item:nth-child(7) {
  transition-delay: 0.4s;
}

.menu-item:nth-child(8) {
  transition-delay: 0.45s;
}

.menu-item:nth-child(9) {
  transition-delay: 0.5s;
}

.menu-item:nth-child(10) {
  transition-delay: 0.55s;
}

.menu-item:nth-child(11) {
  transition-delay: 0.6s;
}

.menu-item:nth-child(12) {
  transition-delay: 0.65s;
}

.menu-link {
  position: relative;
  display: block;
  padding: 0.5rem 0;
  color: var(--menu-text);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: -0.5px;
  font-weight: 900;
  font-size: clamp(2rem, 5vw, 3.5rem);
  transition: transform 0.3s ease, padding-left 0.3s ease;
}

.menu-link::before {
  position: absolute;
  bottom: 0.5rem;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--menu-text);
  content: "";
  transition: width 0.4s ease;
}

.menu-link:hover {
  padding-left: 1.5rem;
}

.menu-link:hover::before {
  width: 80px;
}

.menu-link.active {
  opacity: 0.3;
}

.menu-footer {
  position: relative;
  margin-top: 4rem;
  padding-top: 2rem;
  opacity: 0;
  transition: opacity 0.5s ease 0.7s, transform 0.5s ease 0.7s;
  transform: translateY(20px);
  mergin-bottom: 2rem;
}

.menu-footer-end {
  position: relative;
  margin-top: 3rem;
  padding-top: 2rem;
  opacity: 0;
  transition: opacity 0.5s ease 0.7s, transform 0.5s ease 0.7s;
  transform: translateY(20px);
}

/* Border aligned with text, equal padding on right */
.menu-footer::before {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  height: 1px;
  background: rgba(255, 255, 255, 0.2);
  content: "";
}

.overlay-menu.active .menu-footer {
  opacity: 1;
  transform: translateY(0);
}

.overlay-menu.active .menu-footer-end {
  opacity: 1;
  transform: translateY(0);
}

.menu-footer-text {
  margin-bottom: 1rem;
  color: rgba(255, 255, 255, 0.7);
  font-weight: 300;
  font-size: 0.9rem;
}

.mini-links {
  display: flex;
  flex-direction: row; /* default */
  gap: 1.5rem;
  flex-wrap: wrap;
}

@media (max-width: 900px) {
  .mini-links {
    /*display: block;*/
    flex-direction: column;
    width: 100%;
    align-items: flex-start; /* or center if you prefer */
    gap: 14px;
  }
}
.mini-link {
  color: var(--menu-text);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 600;
  font-size: 0.9rem;
  transition: opacity 0.3s ease;
}

.mini-link:hover {
  opacity: 0.7;
}

[data-theme=dark] .hamburger-icon path {
  stroke: var(--menu-icon);
}

/* Remove any Bootstrap container padding at top */
.container:first-child {
  padding-top: 0 !important;
}

/* Hero wrapper - NO space at top */
.hero-wrapper {
  position: relative;
  overflow: hidden;
  margin: 0;
  padding: 0;
  width: 100%;
  background-color: transparent;
}

.hero-wrapper .container {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.hero-section {
  position: relative;
  display: block;
  overflow: visible;
  margin: 0;
  padding: 0;
  height: 650px;
}

/* Video container - extends beyond container on large screens */
.video-container {
  position: absolute;
  top: 0;
  left: 50%;
  max-width: none;
  width: 1400px;
  height: 650px;
  transform: translateX(-70%);
}

/* Clipped video wrapper */
.clipped-video-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.6s ease;
}

.clipped-video-wrapper.visible {
  opacity: 1;
}

.clipped-image-wrapper {
  position: relative;
  overflow: visible;
  width: 100%;
  height: 100%;
  transition: opacity 0.6s ease;
}

.image-placeholder {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  background-position: center;
  opacity: 1;
  cursor: pointer;
  transition: opacity 0.5s ease;
  -webkit-transform: translateZ(0);
  /* Safari fix: force GPU acceleration */
  transform: translateZ(0);
  object-fit: cover;
  clip-path: url(#clip-video);
  -webkit-clip-path: url(#clip-video);
}

/* Placeholder image - shown until video loads */
.video-placeholder {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  background-position: center;
  background-size: cover;
  opacity: 1;
  cursor: pointer;
  transition: opacity 0.5s ease;
  -webkit-transform: translateZ(0);
  /* Safari fix: force GPU acceleration */
  transform: translateZ(0);
  clip-path: url(#clip-video);
  -webkit-clip-path: url(#clip-video);
}

.video-placeholder.hidden {
  opacity: 0;
  pointer-events: none;
}

/* Video styling - fills the entire container */
.hero-wrapper video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: transparent;
  opacity: 0;
  cursor: pointer;
  transition: opacity 0.5s ease;
  -webkit-transform: translateZ(0);
  /* Safari fixes for clip-path */
  transform: translateZ(0);
  object-fit: cover;
  clip-path: url(#clip-video);
  -webkit-clip-path: url(#clip-video);
  -webkit-mask-image: -webkit-radial-gradient(white, black);
}

.hero-wrapper video.loaded {
  opacity: 1;
}

/* Ensure video is visible when loaded but paused */
.hero-wrapper video.loaded:not(.hidden) {
  display: block;
  visibility: visible;
}

/* Content area */
.content-area {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  padding: 80px 15px;
  min-height: 650px;
  color: white;
  pointer-events: none;
  justify-content: center;
}

.content-box {
  margin-left: auto;
  padding: 40px;
  max-width: 500px;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.4);
  pointer-events: all;
  backdrop-filter: blur(10px);
}

.content-box h1 {
  margin-bottom: 20px;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
  font-size: 3em;
}

.content-box p {
  text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
  font-size: 1.2em;
  line-height: 1.6;
}

/* Hide SVG definition */
.svg-defs {
  position: absolute;
  overflow: hidden;
  width: 0;
  height: 0;
}

/* Responsive adjustments */
@media (max-width: 1200px) {
  .video-container {
    width: 1200px;
  }
  .content-box {
    max-width: 450px;
  }
}
@media (max-width: 991px) {
  .video-container {
    width: 1000px;
    height: 600px;
  }
  .hero-section {
    height: 600px;
  }
  .content-area {
    min-height: 600px;
  }
  .content-box {
    padding: 30px;
    max-width: 400px;
  }
  .content-box h1 {
    font-size: 2.5em;
  }
  .content-box p {
    font-size: 1.1em;
  }
}
@media (max-width: 767px) {
  /* On small screens, show less of left side */
  .video-container {
    left: 60%;
    width: 900px;
    height: 500px;
  }
  .hero-section {
    height: 500px;
  }
  .content-area {
    padding: 60px 15px;
    min-height: 500px;
  }
  .content-box {
    margin: 0;
    padding: 25px;
    max-width: 100%;
  }
  .content-box h1 {
    font-size: 2em;
  }
  .content-box p {
    font-size: 1em;
  }
}
@media (max-width: 480px) {
  .video-container {
    left: 65%;
    width: 700px;
    height: 450px;
  }
  .hero-section {
    height: 450px;
  }
  .content-area {
    padding: 40px 15px;
    min-height: 450px;
  }
  .content-box {
    padding: 20px;
  }
  .content-box h1 {
    font-size: 1.8em;
  }
}
.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

p {
  display: block;
  color: var(--color-text);
  line-height: 1.6;
}

p,
ul,
ol,
li {
  font-size: var(--main-font-size);
}

ul:not(.menu-list a):not(.mini-link):not(.legacy-articles):not(.slick-dots li):not(li.menu-item):not(.tag-list li) {
  padding-left: 0;
  list-style: none;
}

li:not(.menu-list a):not(.mini-link):not(.legacy-articles):not(.slick-dots li):not(li.menu-item):not(.tag-list li) {
  position: relative;
  margin-bottom: 12px;
  padding-left: 40px;
}

li::before:not(.menu-list a):not(.mini-link):not(.legacy-articles):not(.slick-dots li):not(li.menu-item):not(.tag-list li) {
  position: absolute;
  top: 0;
  left: 0;
  width: 24px;
  height: 24px;
  border-radius: 6px; /* Rounded corners */
  background-color: #3b82f6; /* Icon color - blue */
  content: "";
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E");
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
}

.textinput ul {
  padding-left: 20px !important;
  list-style: square !important;
}

.textinput li {
  margin-bottom: 0 !important;
  padding-left: 0 !important;
  line-height: 1.6;
}

.page-title {
  display: block;
  /*text-transform: uppercase;*/
  padding-top: 2.5em;
  font-size: var(--page-text);
}

.text-logo {
  display: block;
  padding-top: 30px;
  color: var(--color-text);
  /*padding-top: 14.5em;*/
  /*padding-left: 2.5em;*/
}

.text-logo.home-page {
  margin-top: -70px;
  padding-top: 0;
}

@media (max-width: 992px) {
  .text-logo.home-page {
    margin-top: -30px;
  }
}
@media (max-width: 768px) {
  .text-logo.home-page {
    margin-top: 10px;
  }
}
.text-logo a,
.text-logo a:hover {
  color: var(--color-text);
  text-decoration: none;
}

.menu-icon-text {
  display: block;
  padding-top: 44px;
  color: var(--menu-icon);
}

/*body {
  display: flex;

  align-items: center;
  justify-content: center;
  touch-action: none;
}*/
.word {
  display: flex;
  text-align: center;
  letter-spacing: -4px;
  /* clamp(smallest font size, scale by of viewport width, max font size) */
  /*font-size: clamp(3rem, 10vw, 10rem);*/
  font-size: clamp(3rem, 10vw, 8rem);
  font-family: "Switzer", system-ui, sans-serif;
  line-height: 0.7;
  pointer-events: none;
  user-select: none;
}

.letter {
  font-variation-settings: "wght" 900;
  will-change: font-variation-settings;
}

.banner {
  /*display: flex;*/
  display: grid;
  padding: 10px;
  /*background: #51d6ff;*/
  background: var(--banner-bg);
  color: var(--banner-text);
  font-weight: 600;
}

.banner p {
  color: var(--banner-text);
  font-size: 1.2em;
}

/*blockquote p {
  margin: 0 0 1rem;
  color: #333;
  font-size: 1.25rem;
  line-height: 1.7;
}

blockquote p:last-child {
  margin-bottom: 0;
}*/
h1,
h2,
h3,
h4,
h5,
h6 {
  padding-top: 20px;
  text-transform: uppercase;
  letter-spacing: -0.5px;
  /*letter-spacing: -.4;*/
  font-weight: 900;
  font-style: normal;
  /*font-family: 'Source Sans Pro', sans-serif;*/
  /*font-family: 'Source Sans 3', sans-serif;*/
  font-family: var(--headline-font);
  line-height: var(--headline-lines);
}

figcaption {
  padding: 5px 0;
  text-align: right;
  font-style: italic;
  opacity: 0.7;
}

::selection {
  /*background-color: #f09;*/
  background-color: var(--highlighter-bg);
  color: var(--highlighter-text);
}

::-moz-selection {
  background-color: var(--highlighter-bg);
  color: var(--highlighter-text);
}

/*.fullbanner {
  padding-top: 10px;
  background: rgb(255,137,0);
  a {
    &:hover {
      border-bottom-color: #f8f6f1;
    }
  }
}*/
.image-text-section {
  padding-bottom: 100px;
}

h2.logo-title {
  padding-left: 70px;
  text-align: left;
  text-transform: none;
  font-weight: 300;
  font-style: italic;
  font-size: 20px;
}

/* Board Feed Styles - Twitter-like Design with Slick Slider */
.board-feed {
  margin: 0 auto;
  padding: 20px;
  max-width: 600px;
  /*background-color: #f7f7f7;*/
}

.board-post {
  margin-bottom: 16px;
  padding: 20px;
  border: 1px solid var(--board-border);
  border-radius: 12px;
  /*background: #fff;*/
  background: var(--board-bg);
  transition: all 0.2s ease;
}

/*.board-post:hover {
  border-color: #d1d8dd;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .1);
}
*/
.post-header {
  display: flex;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--board-headerline);
  justify-content: space-between;
  align-items: baseline;
}

.post-title {
  margin: 0;
  color: var(--board-text);
  font-weight: 700;
  font-size: 18px;
  flex: 1;
}

.post-date {
  margin-left: 12px;
  color: var(--board-date);
  white-space: nowrap;
  font-weight: 400;
  font-size: 14px;
}

.post-content {
  color: var(--board-text);
  word-wrap: break-word;
  font-size: 15px;
  line-height: 1.6;
}

.post-content p {
  margin: 0 0 12px 0;
}

.post-content p:last-child {
  margin-bottom: 0;
}

.post-content img {
  display: block;
  margin: 12px 0;
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}

/* Videos and iframes in posts */
.post-content iframe,
.post-content video,
.post-content embed {
  display: block;
  margin: 12px 0;
  min-height: 315px;
  max-width: 100%;
  width: 100%;
  height: auto;
  border: 1px solid var(--board-border);
  border-radius: 12px;
}

/* Responsive video wrapper for proper aspect ratio */
.post-content .video {
  position: relative;
  overflow: hidden;
  margin: 12px 0;
  /* padding-bottom: 56.25%; */ /* 16:9 aspect ratio */
  padding-bottom: 58.25%; /* 16:9 aspect ratio */
  height: 0;
  border: 1px solid var(--board-border);
  border-radius: 12px;
  background: #000;
}

.post-content .video iframe,
.post-content .video embed {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: 12px;
}

.post-content a {
  color: var(--board-link);
  text-decoration: none;
}

.post-content a:hover {
  border-bottom: 2px solid;
  /*text-decoration: underline;*/
  text-decoration: none;
}

/* No posts message */
.no-posts {
  padding: 40px 20px;
  border: 1px solid var(--board-border);
  border-radius: 12px;
  background: var(--board-bg);
  /*color: #657786;*/
  color: var(--board-text);
  text-align: center;
}

/* Loading indicator */
.board-loading {
  padding: 40px 20px;
  text-align: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.board-loading.active {
  opacity: 1;
}

.loading-spinner {
  margin: 0 auto;
  width: 40px;
  height: 40px;
  border: 4px solid var(--board-border);
  border-top-color: #1da1f2;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* Post Images Section */
.post-images {
  margin-top: 16px;
}

/* Wall-to-wall images when no text content */
.board-post.no-text .post-images {
  margin: 0 -20px -20px -20px;
}

.board-post.no-text .single-image,
.board-post.no-text .post-slider {
  border: none;
  border-radius: 0 0 12px 12px;
}

/* Single Image */
.single-image {
  overflow: hidden;
  border: 1px solid var(--board-border);
  border-radius: 12px;
  background: var(--board-bg);
}

.single-image img {
  display: block;
  width: 100%;
  height: auto;
}

/* ============================================
   SLICK SLIDER STYLES
   ============================================ */
.post-slider {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  background: #000;
}

/* Allow height to adjust smoothly */
.post-slider .slick-list {
  overflow: hidden;
  margin: 0 !important;
  padding: 0 !important;
  /*padding-bottom: 30px;*/
  min-height: 200px;
  background: #000;
  transition: height 450ms ease;
}

.post-slider .slick-list.dragging {
  transition: none;
}

.post-slider .slick-track {
  display: flex !important;
  margin: 0;
  min-height: 200px;
  background: #000;
  align-items: flex-start;
}

/* Slide items - ensure full image display with no gaps */
.post-slider .slick-slide {
  float: left;
  height: auto;
  outline: none;
  background: #000;
}

.post-slider .slick-slide > div {
  width: 100%;
  background: #000;
}

.post-slider .slide-item {
  position: relative;
  width: 100%;
  outline: none;
  background: #000;
  font-size: 0;
  line-height: 0;
}

.post-slider .slide-item img {
  display: block;
  margin: 0;
  padding: 0;
  max-width: 100%;
  width: 100%;
  height: auto;
  border: 0;
  vertical-align: bottom;
  font-size: 0;
  line-height: 0;
}

/* Dots */
.post-slider .slick-dots {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex !important;
  margin: 0;
  padding: 12px 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.3), transparent);
  list-style: none;
  justify-content: center;
  align-items: center;
}

.post-slider .slick-dots li {
  margin: 0 4px;
}

.post-slider .slick-dots li button {
  padding: 0;
  width: 8px;
  height: 8px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  font-size: 0;
  cursor: pointer;
  transition: all 0.2s ease;
}

.post-slider .slick-dots li.slick-active button {
  width: 24px;
  border-color: rgba(0, 0, 0, 0.3);
  border-radius: 4px;
  background: #fff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.post-slider .slick-dots li button:hover {
  background: rgba(255, 255, 255, 0.8);
}

/* Responsive Design */
@media (max-width: 640px) {
  .board-feed {
    padding: 12px;
  }
  .board-post {
    margin-bottom: 12px;
    padding: 16px;
  }
  .board-post.no-text .post-images {
    margin: 0 -16px -16px -16px;
  }
  .post-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .post-date {
    margin-top: 4px;
    margin-left: 0;
  }
  .post-title {
    font-size: 16px;
  }
  .post-content {
    font-size: 14px;
  }
  .post-slider .slick-prev,
  .post-slider .slick-next {
    width: 32px;
    height: 32px;
  }
  .post-slider .slick-prev svg,
  .post-slider .slick-next svg {
    width: 18px;
    height: 18px;
  }
}
figure img,
figure.video {
  margin-top: 10px;
  margin-bottom: 30px;
}

figure.video {
  position: relative;
  overflow: hidden;
  /*padding-top: 25px;*/
  /* 16:9 */
  /*padding-bottom: 56.25%; */
  padding-bottom: 51.45%;
  height: 0;
  border-radius: 30px;
}

figure.video iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/*.image-section {
  overflow: hidden;
  padding: 0;
}

.image-section img {
  display: block;
  width: 100%;
  height: 100vh;

  object-fit: cover;
}
@media (max-width: 768px) {
  .image-section img {
    height: 50vh;
  }

  .text-section {
    padding: 30px 20px;
    min-height: auto;
  }
}
*/
/*.image-text-section {
  position: relative;
  width: 100%;
}
.image-wrapper {
  position: absolute;
  top: 10px;
  z-index: -5;
  width: 80%;
  transform: translateX(-30%) translateY(30%);
}
@media (max-width: 768px) {
  .image-wrapper {
    position: relative;
    width: 100%;
    transform: translateX(0) translateY(0);
  }
}*/
.about-sections {
  margin-right: auto;
  margin-left: auto;
  max-width: 1800px; /* the point past which margins were zeroed */
}

@media (min-width: 1000px) {
  .image-wrapper {
    overflow: hidden;
    margin-bottom: -10%;
    max-width: 1200px;
    width: 100%;
  }
  .image-left .image-wrapper {
    margin-left: -15%;
  }
  .image-right .image-wrapper {
    margin-right: -15%;
  }
  .page-about .image-left .image-wrapper {
    margin-left: -20%;
  }
  .page-about .image-right .image-wrapper {
    margin-right: -20%;
  }
  .image-wrapper img {
    display: block;
    width: 100%;
    height: auto;
  }
  .page-service .image-wrapper {
    margin-bottom: -5%;
  }
}
@media (min-width: 1400px) {
  .page-service .image-wrapper {
    position: relative;
    top: -10%;
    margin-bottom: -10%;
  }
}
@media (max-width: 1000px) {
  .image-anchor {
    width: 100%;
  }
  .image-left .image-wrapper {
    margin-left: -30%;
  }
  .image-right .image-wrapper {
    margin-right: -30%;
  }
  .image-wrapper {
    margin-top: -5%;
    margin-bottom: -5%;
  }
  .image-wrapper img {
    display: block;
    width: 100%;
    height: auto;
  }
  .page-service .image-wrapper {
    margin-bottom: -15%;
  }
}
@media (max-width: 1000px) {
  .page-about .section-block:first-of-type .image-wrapper {
    margin-top: -10%;
  }
}
@media (min-width: 1000px) {
  .page-about .section-block:first-of-type .image-wrapper {
    margin-top: -10%;
  }
}
@media (max-width: 300px) {
  .image-anchor {
    width: 100%;
  }
  .image-left .image-wrapper {
    margin-left: -10%;
  }
  .image-right .image-wrapper {
    margin-right: -10%;
  }
}
@media (max-width: 600px) {
  .image-anchor {
    width: 100%;
  }
  .image-left .image-wrapper {
    margin-left: -10%;
  }
  .image-right .image-wrapper {
    margin-right: -10%;
  }
  .page-about .image-wrapper {
    margin-top: -10%;
    margin-bottom: -10%;
  }
}
@media (max-width: 800px) {
  .page-about .image-wrapper {
    margin-top: -10%;
    margin-bottom: -10%;
  }
}
@media (max-width: 1000px) {
  .page-about .image-wrapper {
    margin-top: -14%;
    margin-bottom: -14%;
  }
}
@media (max-width: 1200px) {
  .page-about .image-wrapper {
    margin-top: -10%;
    margin-bottom: -14%;
  }
}
@media (max-width: 1400px) {
  .page-about .image-wrapper {
    margin-top: -6%;
    margin-bottom: -14%;
  }
}
@media (max-width: 1800px) {
  .page-about .image-wrapper {
    margin-top: -8%;
    margin-bottom: -12%;
  }
}
@media (max-width: 2000px) {
  .page-about .image-wrapper {
    margin-top: -6%;
    margin-bottom: -10%;
  }
}
@media (min-width: 2000px) {
  .page-about .image-wrapper {
    margin-top: -5%;
    margin-bottom: -11%;
  }
}
@media (min-width: 1800px) {
  .image-left .image-wrapper {
    margin-left: 0;
  }
  .image-right .image-wrapper {
    margin-right: 0;
  }
  .page-about .image-left .image-wrapper {
    margin-left: 0;
  }
  .page-about .image-right .image-wrapper {
    margin-right: 0;
  }
}
.right-images {
  float: right;
}

.contact-form {
  position: relative;
  overflow: hidden;
  margin: 0 auto;
  padding-bottom: 50px;
  /*padding: 60px 50px;*/
  max-width: 720px;
  /*border-radius: 24px;*/
  /*background: #fff;*/
  /*box-shadow: 0 2px 20px rgba(0, 0, 0, .04);*/
}

/* Hide honeypot field */
.contact-form .hp {
  position: absolute;
  left: -9999px;
  display: none !important;
  visibility: hidden;
}

.form-group {
  position: relative;
  margin-bottom: 20px;
}

label {
  display: block;
  margin-bottom: 8px;
  color: var(--form-labels);
  text-transform: uppercase;
  font-weight: 900;
  font-size: 14px;
}

input[type=text],
input[type=email],
textarea {
  padding: 12px 16px;
  width: 100%;
  border: 2px solid var(--form-box);
  border-radius: 8px;
  background: var(--form-bg);
  color: var(--form-input);
  font-weight: 600;
  font-size: 18px;
  font-family: inherit;
  transition: border-color 0.3s ease;
}

input[type=text]::placeholder,
input[type=email]::placeholder,
textarea::placeholder {
  font-weight: 400;
  opacity: 0.5;
}

input[type=text]:focus,
input[type=email]:focus,
textarea:focus {
  outline: none;
  border-color: #667eea;
}

/* Auto-expanding textarea styles */
textarea {
  overflow: hidden;
  /*height: 49.3px;*/ /* Start with one line */
  height: 52.6px; /* Start with one line */
  line-height: 1.5;
  resize: none;
  transition: height 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

textarea.expanded {
  height: 140px; /* Height for 5 rows after typing */
}

/* When content exceeds 5 rows, allow dynamic height */
textarea.expanding {
  transition: height 0.2s ease-out;
}

/*.contact-form button {
  margin-top: 10px;
  padding: 14px 32px;
  border: none;
  border-radius: 8px;
  background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  color: white;
  font-weight: 600;
  font-size: 16px;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease;
}

.contact-form button:hover {
  box-shadow: 0 10px 25px rgba(102, 126, 234, .4);
  transform: translateY(-2px);
}

.contact-form button:active {
  transform: translateY(0);
}*/
/* Alert Messages - Hidden by default with styling */
.alert {
  position: relative;
  display: none;
  margin-bottom: 28px;
  padding: 14px 20px;
  border: none;
  border-radius: 10px;
  font-weight: 500;
  font-size: 18px;
}

.alert-success {
  /*border-left: 3px solid #10b981;*/
  /*background: #d1fae5;*/
  background: #39ff88;
  /*color: #065f46;*/
  color: #111;
  font-weight: 500;
}

.alert-danger {
  /*border-left: 3px solid #f59e0b;*/
  /*background: #fef3c7;*/
  background: rgb(252, 244, 3);
  /*color: #92400e;*/
  color: #111;
  font-weight: 500;
}

.alert .close {
  position: absolute;
  top: 50%;
  right: 14px;
  display: flex;
  width: 24px;
  height: 24px;
  border: none;
  border-radius: 50%;
  background: none;
  color: inherit;
  font-weight: 400;
  font-size: 18px;
  line-height: 1;
  opacity: 0.5;
  cursor: pointer;
  transition: all 0.2s ease;
  transform: translateY(-50%);
  align-items: center;
  justify-content: center;
}

.alert .close:hover {
  background: rgba(0, 0, 0, 0.05);
  opacity: 1;
}

:root {
  --padding-large-horizontal: 10px; /* adjust to your design system */
  --padding-large-vertical: 35px; /* adjust to your design system */
  --brand-danger: #e74c3c; /* base danger color */
  --brand-danger-dark: #c0392b; /* darkened version (~15%) */
}

/* Disabled state */
.disabled {
  opacity: 0.5;
}

/* Required state */
.required::after {
  position: absolute;
  top: var(--padding-large-vertical);
  right: var(--padding-large-horizontal);
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 3px;
  background-color: var(--brand-danger-dark);
  content: "";
}

.newsletter-error {
  /*margin-top: 0.75rem;
  color: #c0392b;
  font-size: 0.9rem;*/
  position: relative;
  /*display: none;*/
  margin-bottom: 28px;
  padding: 14px 20px;
  border: none;
  border-radius: 10px;
  background: #fcf403;
  color: #111;
  font-weight: 500;
  font-weight: 500;
  font-size: 18px;
}

input[type=text].is-invalid,
input[type=email].is-invalid,
input[type=text].is-invalid:focus,
input[type=email].is-invalid:focus {
  border-color: #667eea;
}

.checkbox-box.is-invalid {
  border-color: #667eea;
}

button,
button.button,
button.light,
button.grey,
button.gray,
button.none,
.button,
.button.light,
.button.grey,
.button.gray,
.button.none {
  margin: 10px;
  margin: 0 auto;
  text-align: center;
}

/* PRIMARY BUTTON - the clear one */
.button {
  position: relative;
  /*display: block;*/
  padding: 13px 20px 13px;
  outline: 0;
  border: 3px solid var(--button-border);
  border-radius: 9999px;
  background-color: var(--button-border);
  /*background-color: rgba(0, 0, 0, 0);*/
  /*  -webkit-box-shadow: 1px 30px 72px 0 rgba(186,85,211,.37);
     -moz-box-shadow: 1px 30px 72px 0 rgba(186,85,211,.37);
          box-shadow: 1px 30px 72px 0 rgba(186,85,211,.37);*/
  color: var(--button-text);
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 900;
  font-size: 22px;
  cursor: pointer;
  transform: scale(1); /* normal size */
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
}

.button:hover {
  /*  -webkit-box-shadow: 1px 30px 72px 0 rgba(186,85,211,.73);
     -moz-box-shadow: 1px 30px 72px 0 rgba(186,85,211,.73);
          box-shadow: 1px 30px 72px 0 rgba(186,85,211,.73);*/
}

/* PRIMARY LIGHT BUTTON - the light one */
.button.light {
  position: relative;
  display: block;
  padding: 13px 20px 13px;
  outline: 0;
  border: 3px solid var(--button-border);
  border-radius: 9999px;
  /*background-color: var(--button-border);*/
  /*background-color: rgba(0, 0, 0, 0);*/
  background-color: transparent;
  /*  -webkit-box-shadow: 1px 30px 72px 0 rgba(186,85,211,.37);
     -moz-box-shadow: 1px 30px 72px 0 rgba(186,85,211,.37);
          box-shadow: 1px 30px 72px 0 rgba(186,85,211,.37);*/
  /*color: var(--button-text);*/
  color: var(--button-text-light);
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 900;
  font-size: 22px;
  cursor: pointer;
  transform: scale(1); /* normal size */
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
}

.button.light:hover {
  /*  -webkit-box-shadow: 1px 30px 72px 0 rgba(186,85,211,.73);
     -moz-box-shadow: 1px 30px 72px 0 rgba(186,85,211,.73);
          box-shadow: 1px 30px 72px 0 rgba(186,85,211,.73);*/
}

/* SECONDARY BUTTON - minimal design  */
.button.grey,
.button.gray {
  position: relative;
  display: block;
  padding: 13px 20px 13px;
  outline: 0;
  /*border: 3px solid #c4c4c4;*/
  /*border: 3px solid #111;*/
  border: 3px solid var(--seoncary-button);
  border-radius: 9999px;
  background-color: var(--seoncary-button);
  /*  -webkit-box-shadow: 1px 30px 72px 0 rgba(217, 217, 217,.37);
     -moz-box-shadow: 1px 30px 72px 0 rgba(217, 217, 217,.37);
          box-shadow: 1px 30px 72px 0 rgba(217, 217, 217,.37);*/
  /*background-color: rgba(0, 0, 0, 0);*/
  color: var(--button-text-secondary);
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 900;
  font-size: 22px;
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
}

.button.grey:hover,
.button.gray:hover {
  /*  -webkit-box-shadow: 1px 30px 72px 0 rgba(217, 217, 217,.73);
     -moz-box-shadow: 1px 30px 72px 0 rgba(217, 217, 217,.73);
          box-shadow: 1px 30px 72px 0 rgba(217, 217, 217,.73);*/
}

/* TERTIARY BUTTON - Minimal, text-focused */
.button.none {
  position: relative;
  display: block;
  padding: 13px 20px 13px;
  outline: 0;
  border: none;
  background-color: transparent;
  color: var(--button-text-light);
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 900;
  font-size: 22px;
  cursor: pointer;
  transform: scale(1); /* normal size */
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
}

/* underline */
.button.none::after {
  position: absolute;
  bottom: 8px; /* distance from text */
  left: 50%;
  width: 0;
  height: 3px;
  background-color: currentColor;
  content: "";
  transition: width 0.25s ease;
  transform: translateX(-50%);
  /*pointer-events: none;*/
}

/* hover   :not(.button):not(.grey):not(.gray):not(.light)*/
.button.none:hover::after {
  min-width: 0;
  width: fit-content; /* fallback below */
  width: max-content;
}

/* Responsive adjustments for all buttons */
@media (min-width: 768px) {
  .button,
  .button.grey,
  .button.gray,
  .button.none,
  .button.light {
    padding: 17px 100px 17px;
  }
}
.button:hover:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none),
button:hover:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none),
.button:focus:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none),
button:focus:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none),
.button:active:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none),
button:active:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none),
.button:active:focus:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none),
button:active:focus:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none),
.button:active:hover:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none),
button:active:hover:not(.menu-toggle):not(.overlay-close):not(.grey):not(.gray):not(.none) {
  /*border: 2px solid var(--brand);
  background-color: var(--brand);*/
  /*color: #111;*/
  transform: scale(1.08);
  animation: breathe 3s ease-in-out infinite;
}

.button.grey:hover,
button.grey:hover,
.button.grey:focus,
button.grey:focus,
.button.grey:active,
button.grey:active,
.button.grey:active:focus,
button.grey:active:focus,
.button.grey:active:hover,
button.grey:active:hover,
.button.gray:hover,
button.gray:hover,
.button.gray:focus,
button.gray:focus,
.button.gray:active,
button.gray:active,
.button.gray:active:focus,
button.gray:active:focus,
.button.gray:active:hover,
button.gray:active:hover {
  /*border: 2px solid var(--brand);
  background-color: var(--brand);*/
  /*color: #111;*/
  transform: scale(1.08);
  animation: breathegrey 3s ease-in-out infinite;
}

.button.none:hover,
button.none:hover,
.button.none:focus,
button.none:focus,
.button.none:active,
button.none:active,
.button.none:active:focus,
button.none:active:focus,
.button.none:active:hover,
button.none:active:hover {
  /*color: var(--brand);*/
  transform: scale(1);
  /*animation: none;*/
  /*transform: none !important;*/
  animation: none !important;
}

@keyframes breathe {
  0%, 100% {
    box-shadow: 0 15px 30px 10px var(--button-shadow-rgba-low);
  }
  50% {
    box-shadow: 0 15px 30px 10px var(--button-shadow-rgba-high);
  }
}
@keyframes breathegrey {
  0%, 100% {
    box-shadow: 0 15px 30px 10px rgba(217, 217, 217, 0.2);
  }
  50% {
    box-shadow: 0 15px 30px 10px rgba(217, 217, 217, 0.9);
  }
}
.button-icon {
  margin-top: -4px;
}

/*button:not(.grey):not(.gray):not(.none):not(.menu-toggle)::after,
.button:not(.grey):not(.gray):not(.none):not(.menu-toggle)::after {*/
/*display: inline-block;*/
/*margin-left: 0;*/
/*width: .8em;*/
/*height: .8em;*/
/*background: no-repeat center / contain;*/
/*background-color: var(--button-text, currentColor);*/
/*background-image: url('data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' viewBox=\'0 0 24 24\'%3E%3Cpath fill=\'var(--button-text)\' d=\'M7.33 24l-2.83-2.829 9.339-9.175-9.339-9.167 2.83-2.829 12.17 11.996z\'/%3E%3C/svg%3E');*/
/*position: absolute;
  top: 50%;
  right: 1rem;
  width: 1.25rem;
  height: 1.25rem;
  background-image: url('data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' viewBox=\'0 0 24 24\'%3E%3Cpath fill=\'currentColor\' d=\'M7.33 24l-2.83-2.829 9.339-9.175-9.339-9.167 2.83-2.829 12.17 11.996z\'/%3E%3C/svg%3E');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  content: '';
  transform: translateY(-50%);*/
/*content: '';*/
/*vertical-align: -.05em; /* aligns nicely with text */
/*}*/
/*.button-arrow,
.currentColor {
  color: var(--button-text);

  fill: var(--button-text);
  stroke: var(--button-text);
}
*/
button:not(.grey):not(.gray):not(.none):not(.menu-toggle):not(.overlay-close)::after,
.button:not(.grey):not(.gray):not(.none):not(.menu-toggle):not(.overlay-close)::after {
  display: inline-block;
  margin-left: 0;
  width: 0.8em;
  height: 0.8em;
  background-color: var(--button-text, currentColor);
  content: "";
  vertical-align: -0.05em;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M7.33 24l-2.83-2.829 9.339-9.175-9.339-9.167 2.83-2.829 12.17 11.996z'/%3E%3C/svg%3E") no-repeat center/contain;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M7.33 24l-2.83-2.829 9.339-9.175-9.339-9.167 2.83-2.829 12.17 11.996z'/%3E%3C/svg%3E") no-repeat center/contain;
}

.arrow-right::after {
  display: inline-block;
  margin-left: 0;
  width: 0.8em;
  height: 0.8em;
  background-color: var(--button-text-secondary, currentColor);
  content: "";
  vertical-align: -0.05em;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M7.33 24l-2.83-2.829 9.339-9.175-9.339-9.167 2.83-2.829 12.17 11.996z'/%3E%3C/svg%3E") no-repeat center/contain;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M7.33 24l-2.83-2.829 9.339-9.175-9.339-9.167 2.83-2.829 12.17 11.996z'/%3E%3C/svg%3E") no-repeat center/contain;
}

.arrow-left::after {
  display: inline-block;
  margin-left: 0;
  width: 0.8em;
  height: 0.8em;
  background-color: var(--button-text-secondary, currentColor);
  content: "";
  vertical-align: -0.05em;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z'/%3E%3C/svg%3E") no-repeat center/contain;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M16.67 0l2.83 2.829-9.339 9.175 9.339 9.167-2.83 2.829-12.17-11.996z'/%3E%3C/svg%3E") no-repeat center/contain;
}

p:has(a.button) {
  display: block;
  margin: 40px auto;
  text-align: center;
}

/*  .checkbox-wrapper {
  display: inline-block;
}

.checkbox-container {
  position: relative;
  display: inline-block;
  cursor: pointer;
}

.checkbox-input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

.checkbox-box {
  display: flex;
  width: 50px;
  height: 50px;
  border: 3px solid #717171;
  border-radius: 8px;
  background: white;

  align-items: center;
  justify-content: center;
}

.scribble-svg {
  width: 36px;
  height: 36px;
}

.scribble-path {
  fill: none;
  stroke: #39ff88;
  stroke-width: 7;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 40;
  stroke-dashoffset: 40;
}

.checkbox-input:checked + .checkbox-box .scribble-path.line-1 {
  animation: draw .3s ease-in-out forwards;
}

.checkbox-input:checked + .checkbox-box .scribble-path.line-2 {
  animation: draw .3s ease-in-out .3s forwards;
}

@keyframes draw {
  to {
    stroke-dashoffset: 0;
  }
}

.checkbox-input:not(:checked) + .checkbox-box .scribble-path {
  stroke-dashoffset: 40;
}*/
.checkbox-wrapper {
  display: inline-block;
}

.checkbox-container {
  position: relative;
  display: inline-flex;
  cursor: pointer;
  align-items: center;
  gap: 12px;
}

.checkbox-input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

.checkbox-box {
  display: flex;
  width: 50px;
  height: 50px;
  border: 2px solid var(--form-box);
  border-radius: 8px;
  background: var(--form-bg);
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.checkbox-label-text {
  color: var(--form-labels);
  font-size: 16px;
  user-select: none;
}

.scribble-svg {
  width: 36px;
  height: 36px;
}

.scribble-path {
  fill: none;
  stroke: #39ff88;
  stroke-width: 7;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 40;
  stroke-dashoffset: 40;
}

/* First line animates immediately */
.checkbox-input:checked + .checkbox-box .scribble-path.line-1 {
  animation: draw 0.3s ease-in-out forwards;
}

/* Second line animates after first line completes */
.checkbox-input:checked + .checkbox-box .scribble-path.line-2 {
  animation: draw 0.3s ease-in-out 0.3s forwards;
}

@keyframes draw {
  to {
    stroke-dashoffset: 0;
  }
}
/* Reset animation when unchecked */
.checkbox-input:not(:checked) + .checkbox-box .scribble-path {
  stroke-dashoffset: 40;
}

/* Blockquote main style */
blockquote {
  position: relative;
  margin: 80px auto;
  max-width: 620px;
  /*font-family: 'Barlow Condensed', sans-serif;*/
  align-self: center;
}

/* Target the paragraph as the quote */
blockquote p {
  position: relative;
  margin: 0;
  padding: 25px;
  border: 3px solid var(--blockquote-box);
  /*border: solid 2px;*/
  border-radius: 20px;
  color: var(--blockquote-text);
  text-align: center;
  font-weight: normal;
  font-size: 1.8rem;
  /*font-family: 'Abril Fatface', cursive;*/
  font-family: "Sentient", cursive;
  line-height: 1;
}

/* Blockquote right double quotes */
blockquote p:after {
  position: absolute;
  bottom: -60px;
  left: 50px;
  z-index: 3;
  width: 60px;
  height: 60px;
  border: 3px solid var(--blockquote-box);
  border-bottom: none;
  border-left: none;
  border-radius: 0 100% 0 0;
  content: "";
}

blockquote p:before {
  position: absolute;
  bottom: -3px;
  left: 50px;
  z-index: 2;
  width: 80px;
  /*border: 6px solid #292a2b;*/
  border: 6px solid var(--color-bg);
  content: "";
}

/* increase header size after 600px */
@media all and (min-width: 600px) {
  blockquote p {
    font-size: 2.2rem;
    line-height: 1.2;
  }
}
/* Target text after <br> tag */
/*blockquote p br + * {
  position: relative;
  z-index: 1;
  margin: 0;
  margin-left: 150px;
  padding-top: 15px;
  padding-left: 12px;
  color: var(--color-text);
  font-weight: 400;
  font-size: 1.3rem;
  line-height: 1.2;
}*/
/* Style the cite tag (author attribution) */
/*blockquote cite {
  position: relative;
  z-index: 1;
  display: block; 
  margin: 0;
  margin-left: 150px;
  padding-top: 15px;
  padding-left: 12px;
  color: var(--color-text);
  font-weight: 700;
  font-style: normal;
  font-size: 1.3rem;
  font-family: 'Switzer';
  line-height: 1.2;
}

blockquote cite:first-letter {
  margin-left: -12px;
}
*/
/* Style the cite tag (author attribution) - position it outside the box */
blockquote cite {
  position: absolute;
  bottom: -45px; /* Position below the box */
  left: 150px;
  z-index: 1;
  display: block;
  margin: 0;
  padding-left: 12px;
  color: var(--blockquote-text);
  font-weight: 400;
  font-style: normal;
  font-size: 1.3rem;
  font-family: "Switzer";
  line-height: 1.2;
}

blockquote cite:first-letter {
  margin-left: -12px;
}

@media (max-width: 500px) {
  blockquote cite {
    bottom: -55px;
  }
}
/* Footer container */
footer {
  position: relative;
  overflow: hidden;
  min-height: 400px;
  width: 100%;
  /*background: #1a1a2e;*/
}

/* Footer container */
footer.light {
  position: relative;
  overflow: hidden;
  min-height: 100px;
  width: 100%;
  /*background: #1a1a2e;*/
}

/* SVG definitions (hidden) */
.svg-defs {
  position: absolute;
  width: 0;
  height: 0;
}

/* Left side - full background */
.footer-left {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  display: flex;
  padding: 60px;
  width: 30%;
  height: 100%;
  /*background: #1a1a2e;*/
  align-items: center;
}

/* Right side with clip-path */
.footer-right {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  display: flex;
  overflow: hidden;
  padding: 60px;
  width: 70%;
  height: 100%;
  /*background: url('/assets/images/asfalt-background.jpg') center top no-repeat;*/
  background-color: #111;
  transform: translateX(70px) translateY(30px);
  /*background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);*/
  clip-path: url(#clip-video-rotated);
  align-items: center;
  justify-content: flex-end;
}

.footer-right::before {
  position: absolute; /* Positions the pseudo-element relative to the container */
  top: 0;
  left: 0;
  z-index: -1; /* Puts the pseudo-element behind the content */
  width: 100%;
  height: 100%;
  /*background-image: url('your-image.jpg'); /* The background image */
  background-image: url("/assets/images/asfalt-background-low.jpg");
  background-size: cover; /* Ensures the image covers the container */
  content: ""; /* Required for pseudo-elements to render */
  opacity: 0.5; /* Adjust the transparency here (0.0 to 1.0) */
}

.footer-content {
  color: var(--color-text);
}

.footer-content a {
  text-decoration: none;
}

.footer-content a:hover {
  border-bottom: 2px solid;
  text-decoration: none;
}

.footer-left .footer-content {
  max-width: 500px;
}

.footer-right .footer-content {
  max-width: 400px;
  text-align: right;
}

.social-links {
  display: flex;
  gap: 1rem;
}

.footer-right .social-links {
  justify-content: flex-end;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  footer {
    min-height: 600px;
  }
  /* Left side on top */
  .footer-left {
    z-index: 1;
    padding: 40px 30px;
    width: 100%;
    height: 50%;
    justify-content: center;
  }
  .footer-left .footer-content {
    max-width: 100%;
    text-align: center;
  }
  .footer-left .social-links {
    justify-content: center;
  }
  /* Right side below with horizontal wave */
  .footer-right {
    top: 50%;
    z-index: 2;
    /*clip-path: url(#clip-video-mobile);*/
    padding: 40px 30px;
    width: 100%;
    height: 50%;
    justify-content: center;
  }
  .footer-right .footer-content {
    max-width: 100%;
    text-align: center;
  }
  .footer-right .social-links {
    justify-content: center;
  }
}
.footer-end {
  min-height: 50px;
  background: var(--footer-end-bg);
}

.footer-end-text {
  /*padding-top: 30px;*/
}

.footer-end-text p {
  margin: 0;
  padding-top: 18px;
  padding-bottom: 10px;
  color: var(--footer-end-text);
  font-size: 13px;
  line-height: 1;
  opacity: 1;
}

.footer-end-text a {
  color: var(--footer-end-text);
  text-decoration: none;
}

.footer-end-text a:hover {
  border-bottom: 1px solid var(--footer-end-text);
  color: var(--footer-end-text);
  text-decoration: none;
}

/* ── Search Form ── */
.search-area .search-form {
  display: flex;
  flex-direction: column;
  margin: 2rem auto;
  max-width: 560px;
  gap: 1rem;
}

/* Wrapper that holds input + icon */
.search-area .form-group.floating-label.has-icon {
  position: relative;
  display: flex;
  align-items: center;
}

/* The search input */
.search-area .form-group .form-control {
  padding: 0.75rem 3rem 0.75rem 1rem; /* right padding leaves room for icon */
  width: 100%;
  outline: none;
  border: 2px solid #d1d5db;
  border-radius: 8px;
  background: #fff;
  color: #111;
  font-size: 1rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  /* Remove default browser search-input chrome */
  -webkit-appearance: none;
  appearance: none;
}

.search-area .form-group .form-control::placeholder {
  color: #9ca3af;
}

.search-area .form-group .form-control:focus {
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}

/* Icon span — positioned inside the input on the right */
.search-area .form-group span {
  position: absolute;
  right: 0.75rem;
  display: flex;
  color: #6b7280;
  transition: color 0.2s ease;
  pointer-events: none; /* clicks pass through to input */
  align-items: center;
}

.search-area .form-group .form-control:focus ~ span {
  color: #6366f1;
}

.search-area .form-group span svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

/* Hide the submit button visually but keep it accessible */
.search-area input[type=submit] {
  position: absolute;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  margin: -1px;
  padding: 0;
  width: 1px;
  height: 1px;
  border: 0;
  white-space: nowrap;
}

/* ── Results list ── */
/*body.page-article .wrapper .text-logo {
  margin: 90px 0;
}
body.page-article .text-logo.page-article {
  margin: 90px 0;
}*/
.text-logo.page-article {
  margin: 90px 0;
}

/*.page-article .text-logo {
  margin: 90px 0;
}*/
.video-space {
  padding-top: 40px;
  padding-bottom: 40px;
}

.video-area .container {
  overflow: hidden;
}

@media (min-width: 1200px) {
  .video-space {
    padding-top: 100px;
  }
}
/* Blog Section */
.blog-title {
  margin-bottom: 2rem;
  /*color: #2c2c2c;*/
  color: var(--color-text);
  font-weight: 900;
  font-size: 2.5rem;
}

.blog-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.blog-list article {
  padding: 1.5rem 0;
  border-bottom: 2px solid #e0e0e0;
  transition: background-color 0.2s ease;
}

.blog-list article:hover {
  background-color: #f8f8f8;
}

.blog-list article:last-child {
  border-bottom: none;
}

.blog-list header {
  margin: 0;
  padding: 0;
}

.blog-list li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.blog-list h1 {
  margin: 0;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.4;
}

.blog-list a {
  display: inline-block;
  color: var(--color-text);
  text-decoration: none;
  transition: color 0.2s ease;
}

.blog-list a:hover {
  color: #a855f7; /* Purple accent matching the "SIGN UP" button */
  text-decoration: none;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .blog-title {
    font-size: 2rem;
  }
  .blog-list h1 {
    font-size: 1.25rem;
  }
  .blog-list article {
    padding: 1rem 0;
  }
}
ul.blog-list {
  margin: 0;
  margin-bottom: 50px;
  padding: 0;
  border-bottom: 2px #ccc solid;
  list-style: none;
}

ul.blog-list li {
  border-top: 2px #ccc solid;
}

/* Make the link fill the entire li */
ul.blog-list li a {
  display: block;
  padding: 30px 0; /* Add some vertical padding for better clickability */
  padding-right: 20px;
  padding-left: 20px;
  color: var(--a-link);
  text-decoration: none;
  text-transform: uppercase;
  word-wrap: break-word; /* legacy alias for older browsers */
  word-break: break-word; /* fallback */
  hyphens: auto; /* optional: adds hyphens at break points */
  font-weight: 700;
  font-weight: 700;
  font-size: 1.5em;
  line-height: 1;
  transition: color 0.2s ease; /* Smooth transition */
  overflow-wrap: break-word; /* break long words only when needed */
}

/* Hover effect on the link (which now fills the li) */
ul.blog-list li a:hover {
  border-bottom: 0;
  background: var(--article-list-hover-bg);
  color: var(--a-link-hover);
  text-decoration: none;
}

/*li.legacy-articles:hover {
  text-decoration: none;
}
*/
/* Container for the articles grid */
.articles-grid {
  display: grid;
  margin: 40px 0;
  padding-bottom: 100px;
  grid-template-columns: repeat(2, 1fr); /* 2 columns on mobile */
  gap: 16px;
}

@media (min-width: 768px) {
  .articles-grid {
    grid-template-columns: repeat(3, 1fr); /* 3 columns on desktop */
    gap: 24px;
  }
}
/* Each article card */
.articles-grid article {
  overflow: hidden;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.articles-grid article:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  transform: translateY(-4px);
}

/* Image container with text overlay */
.articles-grid .item-image {
  position: relative;
  overflow: hidden;
  padding-top: 65.625%; /* 16:10.5 aspect ratio */
  width: 100%;
  background: #f0f0f0;
}

.articles-grid .item-image > a:first-child {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
}

.articles-grid .item-image img {
  display: block;
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease;
  object-fit: cover;
}

.articles-grid article:hover .item-image img {
  transform: scale(1.05);
}

/* Dark gradient overlay at bottom */
.articles-grid .item-image::after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  height: 70%;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.3) 30%, rgba(0, 0, 0, 0.6) 70%, rgba(0, 0, 0, 0.8) 100%);
  content: "";
  pointer-events: none;
}

/* Title positioned at bottom left */
.articles-grid .item-image h1 {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  margin: 0;
  padding: 16px 20px;
  font-size: 16px;
  line-height: 1.4;
}

@media (min-width: 768px) {
  .articles-grid .item-image h1 {
    padding: 20px 24px;
    font-size: 18px;
  }
}
.articles-grid .item-image h1 a {
  display: block;
  border-bottom: 0;
  color: #fff;
  text-decoration: none;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
  transition: opacity 0.3s ease;
}

.articles-grid article:hover .item-image h1 a {
  opacity: 0.9;
}

.page-article figure img,
.page-article figure.video {
  border-radius: 20px;
}

/* Main wrapper - wall to wall */
.businesses-section-wrapper {
  position: relative;
  overflow: hidden;
  margin: 0;
  padding: 0;
  width: 100%;
}

/* SVG Shapes */
.shape-top,
.shape-bottom {
  position: relative;
  z-index: 1;
  margin-top: 210px;
  margin-bottom: 70px;
  width: 100%;
  height: 120px;
  line-height: 0;
}

.shape-top {
  margin-bottom: -1px;
}

.shape-bottom {
  margin-top: -1px;
}

.shape-top svg,
.shape-bottom svg {
  display: block;
  width: 100%;
  height: 120px;
}

/* Control shape color here */
.shape-fill {
  fill: var(--logo-area-bg);
}

/* Content area background */
.businesses-content {
  position: relative;
  padding: 60px 0;
  background-color: var(--logo-area-bg);
}

.section-title {
  margin-bottom: 50px;
  color: #333;
  text-align: center;
  text-transform: uppercase;
  /*letter-spacing: 2px;*/
  font-weight: 700;
  font-size: 36px;
}

/* Grid adjustments for centering */
.businesses-row {
  display: flex;
  margin-right: -15px;
  margin-left: -15px;
  flex-wrap: wrap;
  justify-content: center;
}

.businesses-row > [class*=col-] {
  display: flex;
  justify-content: center;
}

/* Business item card */
.business-item {
  display: flex;
  flex-direction: column;
  margin-bottom: 30px;
  /*background: white;*/
  /*border-radius: 8px;*/
  padding: 30px 20px;
  min-height: 200px;
  max-width: 320px;
  width: 100%;
  /*box-shadow: 0 3px 10px rgba(0,0,0,0.1);*/
  transition: all 0.3s ease;
  align-items: center;
  justify-content: center;
}

.business-item:hover {
  /*transform: translateY(-5px);*/
  /*box-shadow: 0 5px 20px rgba(0,0,0,0.15);*/
}

/* Logo container for perfect centering */
.logo-container {
  display: flex;
  margin-bottom: 20px;
  width: 100%;
  height: 120px;
  align-items: center;
  justify-content: center;
}

/* Logo styling - works for both SVG and raster */
.business-logo {
  display: block;
  max-width: 100%;
  max-height: 120px;
  width: auto;
  height: auto;
}

/* For SVG objects specifically */
object.business-logo {
  pointer-events: none;
}

.business-name {
  margin: 0;
  color: #333;
  text-align: center;
  word-wrap: break-word;
  font-weight: 600;
  font-size: 18px;
}

/* Responsive adjustments */
@media (max-width: 991px) {
  .shape-top,
  .shape-bottom {
    height: 80px;
  }
  .shape-top svg,
  .shape-bottom svg {
    height: 80px;
  }
}
@media (max-width: 767px) {
  .businesses-content {
    padding: 40px 0;
  }
  .section-title {
    margin-bottom: 30px;
    font-size: 28px;
  }
  .shape-top,
  .shape-bottom {
    height: 60px;
  }
  .shape-top svg,
  .shape-bottom svg {
    height: 60px;
  }
  .business-item {
    max-width: 100%;
  }
}
/* Remove Bootstrap container padding to achieve wall-to-wall */
.container-fluid {
  padding-right: 15px;
  padding-left: 15px;
}

.services-timeline {
  padding: 60px 20px;
  /*background: #f5f5f7;*/
}

.timeline-wrapper {
  position: relative;
  margin: 0 auto;
  max-width: 1200px;
}

/* Continuous vertical line running through all items */
.timeline-line-full {
  position: absolute;
  top: 12px;
  bottom: 0;
  left: 10px;
  z-index: 1;
  width: 4px;
  background: var(--brand);
  opacity: 0.3;
}

/* Each row contains a circle and content */
.timeline-row {
  position: relative;
  display: flex;
  gap: 60px;
  align-items: flex-start;
}

/* Timeline sidebar with dot */
.timeline-sidebar {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  width: 24px;
  flex-shrink: 0;
  align-items: center;
}

.timeline-dot {
  margin-top: 5px;
  width: 22px;
  height: 22px;
  border: 3px solid var(--brand);
  border-radius: 50%;
  background: var(--brand);
  flex-shrink: 0;
}

/* Service content */
.service-item {
  display: block;
  padding-bottom: 80px;
  color: inherit;
  text-decoration: none;
  transition: transform 0.2s ease;
  flex: 1;
}

.timeline-row:last-child .service-item {
  padding-bottom: 0;
}

.service-item:hover {
  border-bottom: 0;
  transform: translateX(5px);
}

.service-item h3 {
  margin: 0 0 20px 0;
  color: var(--color-text);
  text-transform: uppercase;
  /*letter-spacing: -.5px;*/
  font-weight: 700;
  font-size: 28px;
  transition: color 0.3s ease;
}

.service-item:hover h3 {
  /*color: #06c;*/
  color: var(--a-link);
}

.service-text {
  margin-bottom: 20px;
  max-width: 600px;
  color: var(--color-text);
  /*font-size: 16px;*/
  line-height: 1.6;
}

.read-more {
  display: inline-flex;
  /*color: #06c;*/
  color: var(--a-link);
  text-decoration: none;
  font-weight: 600;
  font-size: 16px;
  transition: gap 0.2s ease;
  align-items: center;
  gap: 8px;
}

.service-item:hover .read-more {
  color: var(--a-link-hover);
  gap: 12px;
}

/*.arrow-icon {
  display: inline-block;
  width: 12px;
  height: 12px;
  background-image: url('data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' viewBox=\'0 0 24 24\'%3E%3Cpath fill=\'%230066cc\' d=\'M7.33 24l-2.83-2.829 9.339-9.175-9.339-9.167 2.83-2.829 12.17 11.996z\'/%3E%3C/svg%3E');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  transition: transform .2s ease;
}*/
.arrow-icon {
  display: inline-block;
  margin-bottom: -2px;
  width: 12px;
  height: 12px;
  background-color: var(--a-link);
  transition: transform 0.2s ease;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7.33 24l-2.83-2.829 9.339-9.175-9.339-9.167 2.83-2.829 12.17 11.996z'/%3E%3C/svg%3E");
  mask-position: center;
  mask-size: contain;
  mask-repeat: no-repeat;
}

.service-item:hover .arrow-icon {
  transform: translateX(4px);
}

/* Responsive */
@media (max-width: 768px) {
  .timeline-line-full {
    left: 10px;
  }
  .timeline-row {
    gap: 30px;
  }
  .timeline-sidebar {
    width: 20px;
  }
  .timeline-dot {
    width: 20px;
    height: 20px;
  }
  .service-item {
    padding-bottom: 60px;
  }
  .service-item h3 {
    font-size: 24px;
  }
}
@media (max-width: 480px) {
  .services-timeline {
    padding: 40px 15px;
  }
  .timeline-line-full {
    left: 9px;
  }
  .timeline-row {
    gap: 20px;
  }
  .timeline-sidebar {
    width: 18px;
  }
  .timeline-dot {
    width: 18px;
    height: 18px;
    border-width: 2px;
  }
  .service-item {
    padding-bottom: 50px;
  }
  .service-item h3 {
    font-size: 20px;
  }
  .service-text {
    font-size: 14px;
  }
}
/* Container for the articles grid */
.video-grid {
  display: grid;
  margin: 40px 0;
  padding-bottom: 100px;
  grid-template-columns: repeat(1, 1fr); /* 2 columns on mobile */
  gap: 16px;
}

@media (min-width: 768px) {
  .video-grid {
    grid-template-columns: repeat(2, 1fr); /* 3 columns on desktop */
    gap: 24px;
  }
}
/* Each article card */
.video-grid article {
  overflow: hidden;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.video-grid article:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  transform: translateY(-4px);
}

/* Image container with text overlay */
.video-grid .item-image {
  position: relative;
  overflow: hidden;
  padding-top: 65.625%; /* 16:10.5 aspect ratio */
  width: 100%;
  background: #f0f0f0;
}

.video-grid .item-image > a:first-child {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
}

.video-grid .item-image img {
  display: block;
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease;
  object-fit: cover;
}

.video-grid article:hover .item-image img {
  transform: scale(1.05);
}

/* Dark gradient overlay at bottom */
.video-grid .item-image::after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  height: 70%;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.3) 30%, rgba(0, 0, 0, 0.6) 70%, rgba(0, 0, 0, 0.8) 100%);
  content: "";
  pointer-events: none;
}

/* Title positioned at bottom left */
.video-grid .item-image h1 {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  margin: 0;
  padding: 16px 20px;
  font-size: 16px;
  line-height: 1.4;
}

@media (min-width: 768px) {
  .video-grid .item-image h1 {
    padding: 20px 24px;
    font-size: 18px;
  }
}
.video-grid .item-image h1 a {
  display: block;
  border-bottom: 0;
  color: #fff;
  text-decoration: none;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
  transition: opacity 0.3s ease;
}

.video-grid article:hover .item-image h1 a {
  opacity: 0.9;
}

.page-article figure img,
.page-article figure.video {
  border-radius: 20px;
}

/* Container for the articles grid */
.video-latest {
  display: grid;
  margin: 40px 0;
  margin-bottom: 40px;
  padding-bottom: 100px;
}

/* Each article card */
.video-latest article {
  overflow: hidden;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.video-latest article:hover {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
  transform: translateY(-4px);
}

/* Image container with text overlay */
.video-latest .item-image {
  position: relative;
  overflow: hidden;
  padding-top: 65.625%; /* 16:10.5 aspect ratio */
  width: 100%;
  border-radius: 20px;
  background: #111;
}

.video-latest .item-image > a:first-child {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
}

.video-latest .item-image img {
  display: block;
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease;
  object-fit: cover;
}

.video-latest article:hover .item-image img {
  transform: scale(1.05);
}

/* Dark gradient overlay at bottom */
.video-latest .item-image::after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  height: 70%;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.3) 30%, rgba(0, 0, 0, 0.6) 70%, rgba(0, 0, 0, 0.8) 100%);
  content: "";
  pointer-events: none;
}

/* Title positioned at bottom left */
.video-latest .item-image h1 {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  margin: 0;
  padding: 16px 20px;
  font-size: 24px;
  line-height: 1.4;
}

@media (min-width: 768px) {
  .video-latest .item-image h1 {
    padding: 20px 24px;
    font-size: 32px;
  }
}
@media (max-width: 400px) {
  .video-latest .item-image h1 {
    padding: 20px 24px;
    font-size: 18px;
  }
}
.video-latest .item-image h1 a {
  display: block;
  border-bottom: 0;
  color: #fff;
  text-decoration: none;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
  transition: opacity 0.3s ease;
}

.video-latest article:hover .item-image h1 a {
  opacity: 0.9;
}

.page-article figure img,
.page-article figure.video {
  border-radius: 20px;
}

/*a,
:where(:not(.banner) a) {
  color: var(--a-link);
  text-decoration: none;
}

a:hover:not(.menu-link)
:not(.mini-link)
:not(.dynamic-text)
:not(button)
:not(.button)
:not(.light)
:not(.grey)
:not(.gray)
:not(.none),
:where(:not(.banner) a):hover
:not(.menu-link)
:not(.mini-link)
:not(.dynamic-text)
:not(button)
:not(.button)
:not(.light)
:not(.grey)
:not(.gray)
:not(.none) {
  border-bottom: 2px solid;
  color: var(--a-link-hover);
  text-decoration: none;
}
.banner a {
  color: var(--banner-link);
  text-decoration: none;
}
.banner a:hover,
.banner a:focus,
.banner a:active {
  border-bottom: 2px solid;
  color: var(--banner-link);
  text-decoration: none;
}

.page-error a:not(.button):not(.menu-list a):not(.mini-link) {
  color: var(--a-link);
  text-decoration: none;
}
.page-error a:hover:not(.button):not(.menu-list a):not(.mini-link) {
  border-bottom: 2px solid;
  color: var(--a-link-hover);
  text-decoration: none;
}

.user-input a {
  color: var(--a-link);
  text-decoration: none;
}
.user-input a:hover {
  border-bottom: 2px solid;
  color: var(--a-link-hover);
  text-decoration: none;
}
*/
/* Base link styles - scoped to avoid interference */
a {
  color: var(--a-link);
  text-decoration: none;
}

/* Base hover state - with explicit exclusions */
a:hover:where(:not(.menu-link):not(.mini-link):not(.dynamic-text):not(button):not(.button):not(.light):not(.grey):not(.gray):not(.none)) {
  border-bottom: 2px solid;
  color: var(--a-link-hover);
}

/* Banner context - higher specificity to override base */
.banner a {
  color: var(--banner-link);
}

.banner a:is(:hover, :focus, :active) {
  border-bottom: 2px solid;
  color: var(--banner-link);
}

/* Page error context */
/*.page-error a:where(:not(.button):not(.menu-list a):not(.mini-link)) {
  color: var(--a-link);
}

.page-error a:hover:where(:not(.button):not(.menu-list a):not(.mini-link)) {
  border-bottom: 2px solid;
  color: var(--a-link-hover);
}*/
/* User input context */
.user-input a:not(.button) {
  color: var(--a-link);
}

.user-input a:hover:where(:not(.menu-link):not(.mini-link):not(.dynamic-text):not(button):not(.button):not(.light):not(.grey):not(.gray):not(.none)) {
  border-bottom: 2px solid;
  color: var(--a-link-hover);
}

:root {
  --linktree-accent: #b57ce0;
  --linktree-accent-hover: #9f5dd4;
}

.linktree-container {
  position: relative;
  margin: 0 auto;
  padding: 60px 24px;
  max-width: 680px;
}

.linktree-hero {
  position: relative;
  z-index: 1;
  margin-bottom: 60px;
  text-align: center;
  animation: slideDown 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.linktree-links {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.link-item {
  position: relative;
  display: flex;
  padding: 28px 36px;
  border: 2px solid var(--linktree-border);
  border-radius: 16px;
  background: var(--linktree-card-bg);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  color: var(--linktree-text);
  text-decoration: none;
  font-weight: 700;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) backwards;
  align-items: center;
  justify-content: space-between;
}

.link-item:nth-child(1) {
  animation-delay: 0.1s;
}

.link-item:nth-child(2) {
  animation-delay: 0.2s;
}

.link-item:nth-child(3) {
  animation-delay: 0.3s;
}

.link-item:nth-child(4) {
  animation-delay: 0.4s;
}

.link-item:nth-child(5) {
  animation-delay: 0.5s;
}

.link-item:nth-child(6) {
  animation-delay: 0.6s;
}

.link-item:nth-child(7) {
  animation-delay: 0.7s;
}

.link-item:nth-child(8) {
  animation-delay: 0.8s;
}

.link-item:nth-child(9) {
  animation-delay: 0.9s;
}

.link-item:nth-child(10) {
  animation-delay: 1s;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.link-item:hover {
  border-color: var(--brand);
  background: var(--brand);
  box-shadow: 0 8px 24px rgba(181, 124, 224, 0.2);
  transform: translateY(-4px);
}

.link-item:active {
  box-shadow: 0 4px 12px rgba(181, 124, 224, 0.15);
  transform: translateY(-2px);
}

.link-text {
  position: relative;
  z-index: 1;
  transition: color 0.3s ease;
}

.link-item:hover .link-text {
  color: var(--linktree-hover-text);
}

.link-arrow {
  position: relative;
  z-index: 1;
  margin-top: 8px;
  color: var(--linktree-text);
  font-size: 22px;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.link-item .link-arrow path {
  fill: var(--linktree-text);
}

.link-item:hover .link-arrow path {
  fill: var(--linktree-hover-text);
}

.link-item:hover .link-arrow {
  color: var(--linktree-text);
  transform: translateX(6px);
}

.linktree-footer {
  position: relative;
  z-index: 1;
  margin-top: 60px;
  padding-top: 32px;
}

@media (max-width: 640px) {
  .linktree-container {
    padding: 40px 20px;
  }
  .linktree-hero {
    margin-bottom: 48px;
  }
  .link-item {
    padding: 24px 28px;
    border-radius: 14px;
    font-size: 17px;
  }
  .link-arrow {
    font-size: 22px;
  }
}
ul.tag-list {
  display: flex;
  margin: 0;
  padding: 0;
  list-style: none; /* Remove bullets */
  justify-content: flex-end; /* Right align */
  gap: 0.75rem; /* Space between tags */
}

ul.tag-list li {
  margin: 0;
}

ul.tag-list a {
  text-decoration: none;
}

ul.tag-list {
  flex-wrap: wrap;
}

/* user-input Markdown tables */
.user-input table {
  overflow: hidden;
  margin: 2em 0;
  width: 100%;
  border-collapse: collapse;
  border-radius: 6px;
}

.user-input th,
.user-input td {
  padding: 10px 12px;
  border: 1px solid #ddd;
  text-align: left;
}

.user-input th {
  background: #f5f5f5;
  font-weight: 600;
}

.user-input tr:nth-child(even) {
  background: #fdfafa;
}

.user-input table {
  display: block;
  overflow-x: auto;
}

.user-input th {
  background: var(--table-head, #f5f5f5);
}

[data-theme=dark] .user-input th {
  background: #222;
}
[data-theme=dark] .user-input td,
[data-theme=dark] .user-input th {
  border-color: #444;
}
[data-theme=dark] .user-input tr:nth-child(even) {
  background: #1a1a1a;
}

/*.highlight {
  position: relative;
  display: inline-block;
  padding: .2em .3em;
  background: linear-gradient(to bottom, transparent 20%, rgba(255, 255, 0, .6) 20%, rgba(255, 255, 0, .6) 80%, transparent 80%),
  linear-gradient(to bottom, transparent 40%, rgba(255, 255, 0, .4) 40%, rgba(255, 255, 0, .4) 60%, transparent 60%),
  linear-gradient(90deg, rgba(255, 255, 0, .8) 45%, rgba(255, 255, 0, .8) 55%),
  linear-gradient(90deg, rgba(0, 0, 0, .2) 0%, rgba(0, 0, 0, .2) 2px, transparent 2px);
  background-size: 100% 100%, 100% 100%, 100% 3px, 100% 2px;
  background-repeat: no-repeat;
  font-weight: bold;
  line-height: 1.5;
}

.highlight::before {
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  height: 2px;
  background: rgba(0, 0, 0, .2);
  content: '';
  transform: translateY(-50%) rotate(-1deg);
}
*/
span.mark.yellow {
  background-color: rgba(252, 244, 3, 0.8);
  color: var(--mark-tag-text);
}

span.mark.yellow h1,
span.mark.yellow h2,
span.mark.yellow h3,
span.mark.yellow h4,
span.mark.yellow h5,
span.mark.yellow h6 {
  line-height: 1;
}

.highlight {
  position: relative;
  z-index: 0;
}

.highlight::before {
  position: absolute;
  right: -0.3em;
  bottom: 0.1em;
  left: -0.3em;
  z-index: -1;
  height: 0.6em;
  border-radius: 0.2em;
  background: rgba(252, 244, 3, 0.8);
  content: "";
}
/*!
 * animate.css -https://daneden.github.io/animate.css/
 * Version - 3.7.2
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2019 Daniel Eden
 */
@-webkit-keyframes bounce {
  0%, 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: translateZ(0);
    transform: translateZ(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 {
  0%, 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: translateZ(0);
    transform: translateZ(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 {
  0%, 50%, to {
    opacity: 1;
  }
  25%, 75% {
    opacity: 0;
  }
}
@keyframes flash {
  0%, 50%, to {
    opacity: 1;
  }
  25%, 75% {
    opacity: 0;
  }
}
.flash {
  -webkit-animation-name: flash;
  animation-name: flash;
}

@-webkit-keyframes pulse {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
}
@keyframes pulse {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
  50% {
    -webkit-transform: scale3d(1.05, 1.05, 1.05);
    transform: scale3d(1.05, 1.05, 1.05);
  }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
}
.pulse {
  -webkit-animation-name: pulse;
  animation-name: pulse;
}

@-webkit-keyframes rubberBand {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(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: scaleX(1);
    transform: scaleX(1);
  }
}
@keyframes rubberBand {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(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: scaleX(1);
    transform: scaleX(1);
  }
}
.rubberBand {
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand;
}

@-webkit-keyframes shake {
  0%, to {
    -webkit-transform: translateZ(0);
    transform: translateZ(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 {
  0%, to {
    -webkit-transform: translateZ(0);
    transform: translateZ(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: rotate(15deg);
    transform: rotate(15deg);
  }
  40% {
    -webkit-transform: rotate(-10deg);
    transform: rotate(-10deg);
  }
  60% {
    -webkit-transform: rotate(5deg);
    transform: rotate(5deg);
  }
  80% {
    -webkit-transform: rotate(-5deg);
    transform: rotate(-5deg);
  }
  to {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
}
@keyframes swing {
  20% {
    -webkit-transform: rotate(15deg);
    transform: rotate(15deg);
  }
  40% {
    -webkit-transform: rotate(-10deg);
    transform: rotate(-10deg);
  }
  60% {
    -webkit-transform: rotate(5deg);
    transform: rotate(5deg);
  }
  80% {
    -webkit-transform: rotate(-5deg);
    transform: rotate(-5deg);
  }
  to {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
}
.swing {
  -webkit-transform-origin: top center;
  transform-origin: top center;
  -webkit-animation-name: swing;
  animation-name: swing;
}

@-webkit-keyframes tada {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
  10%, 20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate(-3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate(-3deg);
  }
  30%, 50%, 70%, 90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
  }
  40%, 60%, 80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
  }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
}
@keyframes tada {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
  10%, 20% {
    -webkit-transform: scale3d(0.9, 0.9, 0.9) rotate(-3deg);
    transform: scale3d(0.9, 0.9, 0.9) rotate(-3deg);
  }
  30%, 50%, 70%, 90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
  }
  40%, 60%, 80% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
  }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
  }
}
.tada {
  -webkit-animation-name: tada;
  animation-name: tada;
}

@-webkit-keyframes wobble {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate(-5deg);
    transform: translate3d(-25%, 0, 0) rotate(-5deg);
  }
  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate(3deg);
    transform: translate3d(20%, 0, 0) rotate(3deg);
  }
  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate(-3deg);
    transform: translate3d(-15%, 0, 0) rotate(-3deg);
  }
  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate(2deg);
    transform: translate3d(10%, 0, 0) rotate(2deg);
  }
  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate(-1deg);
    transform: translate3d(-5%, 0, 0) rotate(-1deg);
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes wobble {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  15% {
    -webkit-transform: translate3d(-25%, 0, 0) rotate(-5deg);
    transform: translate3d(-25%, 0, 0) rotate(-5deg);
  }
  30% {
    -webkit-transform: translate3d(20%, 0, 0) rotate(3deg);
    transform: translate3d(20%, 0, 0) rotate(3deg);
  }
  45% {
    -webkit-transform: translate3d(-15%, 0, 0) rotate(-3deg);
    transform: translate3d(-15%, 0, 0) rotate(-3deg);
  }
  60% {
    -webkit-transform: translate3d(10%, 0, 0) rotate(2deg);
    transform: translate3d(10%, 0, 0) rotate(2deg);
  }
  75% {
    -webkit-transform: translate3d(-5%, 0, 0) rotate(-1deg);
    transform: translate3d(-5%, 0, 0) rotate(-1deg);
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.wobble {
  -webkit-animation-name: wobble;
  animation-name: wobble;
}

@-webkit-keyframes jello {
  0%, 11.1%, to {
    -webkit-transform: translateZ(0);
    transform: translateZ(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 {
  0%, 11.1%, to {
    -webkit-transform: translateZ(0);
    transform: translateZ(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 heartBeat {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
  14% {
    -webkit-transform: scale(1.3);
    transform: scale(1.3);
  }
  28% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
  42% {
    -webkit-transform: scale(1.3);
    transform: scale(1.3);
  }
  70% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}
@keyframes heartBeat {
  0% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
  14% {
    -webkit-transform: scale(1.3);
    transform: scale(1.3);
  }
  28% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
  42% {
    -webkit-transform: scale(1.3);
    transform: scale(1.3);
  }
  70% {
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}
.heartBeat {
  -webkit-animation-name: heartBeat;
  animation-name: heartBeat;
  -webkit-animation-duration: 1.3s;
  animation-duration: 1.3s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
}

@-webkit-keyframes bounceIn {
  0%, 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: scaleX(1);
    transform: scaleX(1);
  }
}
@keyframes bounceIn {
  0%, 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: scaleX(1);
    transform: scaleX(1);
  }
}
.bounceIn {
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-animation-name: bounceIn;
  animation-name: bounceIn;
}

@-webkit-keyframes bounceInDown {
  0%, 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: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes bounceInDown {
  0%, 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: translateZ(0);
    transform: translateZ(0);
  }
}
.bounceInDown {
  -webkit-animation-name: bounceInDown;
  animation-name: bounceInDown;
}

@-webkit-keyframes bounceInLeft {
  0%, 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: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes bounceInLeft {
  0%, 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: translateZ(0);
    transform: translateZ(0);
  }
}
.bounceInLeft {
  -webkit-animation-name: bounceInLeft;
  animation-name: bounceInLeft;
}

@-webkit-keyframes bounceInRight {
  0%, 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: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes bounceInRight {
  0%, 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: translateZ(0);
    transform: translateZ(0);
  }
}
.bounceInRight {
  -webkit-animation-name: bounceInRight;
  animation-name: bounceInRight;
}

@-webkit-keyframes bounceInUp {
  0%, 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, -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: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes bounceInUp {
  0%, 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, -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: translateZ(0);
    transform: translateZ(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 {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.fadeIn {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
}

@-webkit-keyframes fadeInDown {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes fadeInDown {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.fadeInDown {
  -webkit-animation-name: fadeInDown;
  animation-name: fadeInDown;
}

@-webkit-keyframes fadeInDownBig {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes fadeInDownBig {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.fadeInDownBig {
  -webkit-animation-name: fadeInDownBig;
  animation-name: fadeInDownBig;
}

@-webkit-keyframes fadeInLeft {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes fadeInLeft {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.fadeInLeft {
  -webkit-animation-name: fadeInLeft;
  animation-name: fadeInLeft;
}

@-webkit-keyframes fadeInLeftBig {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes fadeInLeftBig {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.fadeInLeftBig {
  -webkit-animation-name: fadeInLeftBig;
  animation-name: fadeInLeftBig;
}

@-webkit-keyframes fadeInRight {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes fadeInRight {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.fadeInRight {
  -webkit-animation-name: fadeInRight;
  animation-name: fadeInRight;
}

@-webkit-keyframes fadeInRightBig {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes fadeInRightBig {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.fadeInRightBig {
  -webkit-animation-name: fadeInRightBig;
  animation-name: fadeInRightBig;
}

@-webkit-keyframes fadeInUp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes fadeInUp {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp;
}

@-webkit-keyframes fadeInUpBig {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes fadeInUpBig {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.fadeInUpBig {
  -webkit-animation-name: fadeInUpBig;
  animation-name: fadeInUpBig;
}

@-webkit-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.fadeOut {
  -webkit-animation-name: fadeOut;
  animation-name: fadeOut;
}

@-webkit-keyframes fadeOutDown {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}
@keyframes fadeOutDown {
  0% {
    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 {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, 2000px, 0);
    transform: translate3d(0, 2000px, 0);
  }
}
@keyframes fadeOutDownBig {
  0% {
    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 {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}
@keyframes fadeOutLeft {
  0% {
    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 {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(-2000px, 0, 0);
    transform: translate3d(-2000px, 0, 0);
  }
}
@keyframes fadeOutLeftBig {
  0% {
    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 {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}
@keyframes fadeOutRight {
  0% {
    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 {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(2000px, 0, 0);
    transform: translate3d(2000px, 0, 0);
  }
}
@keyframes fadeOutRightBig {
  0% {
    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 {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}
@keyframes fadeOutUp {
  0% {
    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 {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(0, -2000px, 0);
    transform: translate3d(0, -2000px, 0);
  }
}
@keyframes fadeOutUpBig {
  0% {
    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 {
  0% {
    -webkit-transform: perspective(400px) scaleX(1) translateZ(0) rotateY(-1turn);
    transform: perspective(400px) scaleX(1) translateZ(0) rotateY(-1turn);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  40% {
    -webkit-transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-190deg);
    transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  50% {
    -webkit-transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-170deg);
    transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  80% {
    -webkit-transform: perspective(400px) scale3d(0.95, 0.95, 0.95) translateZ(0) rotateY(0deg);
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95) translateZ(0) rotateY(0deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  to {
    -webkit-transform: perspective(400px) scaleX(1) translateZ(0) rotateY(0deg);
    transform: perspective(400px) scaleX(1) translateZ(0) rotateY(0deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
}
@keyframes flip {
  0% {
    -webkit-transform: perspective(400px) scaleX(1) translateZ(0) rotateY(-1turn);
    transform: perspective(400px) scaleX(1) translateZ(0) rotateY(-1turn);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  40% {
    -webkit-transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-190deg);
    transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  50% {
    -webkit-transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-170deg);
    transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  80% {
    -webkit-transform: perspective(400px) scale3d(0.95, 0.95, 0.95) translateZ(0) rotateY(0deg);
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95) translateZ(0) rotateY(0deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  to {
    -webkit-transform: perspective(400px) scaleX(1) translateZ(0) rotateY(0deg);
    transform: perspective(400px) scaleX(1) translateZ(0) rotateY(0deg);
    -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 {
  0% {
    -webkit-transform: perspective(400px) rotateX(90deg);
    transform: perspective(400px) rotateX(90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    -webkit-transform: perspective(400px) rotateX(-20deg);
    transform: perspective(400px) rotateX(-20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  60% {
    -webkit-transform: perspective(400px) rotateX(10deg);
    transform: perspective(400px) rotateX(10deg);
    opacity: 1;
  }
  80% {
    -webkit-transform: perspective(400px) rotateX(-5deg);
    transform: perspective(400px) rotateX(-5deg);
  }
  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}
@keyframes flipInX {
  0% {
    -webkit-transform: perspective(400px) rotateX(90deg);
    transform: perspective(400px) rotateX(90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    -webkit-transform: perspective(400px) rotateX(-20deg);
    transform: perspective(400px) rotateX(-20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  60% {
    -webkit-transform: perspective(400px) rotateX(10deg);
    transform: perspective(400px) rotateX(10deg);
    opacity: 1;
  }
  80% {
    -webkit-transform: perspective(400px) rotateX(-5deg);
    transform: perspective(400px) rotateX(-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 {
  0% {
    -webkit-transform: perspective(400px) rotateY(90deg);
    transform: perspective(400px) rotateY(90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    -webkit-transform: perspective(400px) rotateY(-20deg);
    transform: perspective(400px) rotateY(-20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  60% {
    -webkit-transform: perspective(400px) rotateY(10deg);
    transform: perspective(400px) rotateY(10deg);
    opacity: 1;
  }
  80% {
    -webkit-transform: perspective(400px) rotateY(-5deg);
    transform: perspective(400px) rotateY(-5deg);
  }
  to {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
}
@keyframes flipInY {
  0% {
    -webkit-transform: perspective(400px) rotateY(90deg);
    transform: perspective(400px) rotateY(90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    -webkit-transform: perspective(400px) rotateY(-20deg);
    transform: perspective(400px) rotateY(-20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  60% {
    -webkit-transform: perspective(400px) rotateY(10deg);
    transform: perspective(400px) rotateY(10deg);
    opacity: 1;
  }
  80% {
    -webkit-transform: perspective(400px) rotateY(-5deg);
    transform: perspective(400px) rotateY(-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 {
  0% {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
  30% {
    -webkit-transform: perspective(400px) rotateX(-20deg);
    transform: perspective(400px) rotateX(-20deg);
    opacity: 1;
  }
  to {
    -webkit-transform: perspective(400px) rotateX(90deg);
    transform: perspective(400px) rotateX(90deg);
    opacity: 0;
  }
}
@keyframes flipOutX {
  0% {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
  30% {
    -webkit-transform: perspective(400px) rotateX(-20deg);
    transform: perspective(400px) rotateX(-20deg);
    opacity: 1;
  }
  to {
    -webkit-transform: perspective(400px) rotateX(90deg);
    transform: perspective(400px) rotateX(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 {
  0% {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
  30% {
    -webkit-transform: perspective(400px) rotateY(-15deg);
    transform: perspective(400px) rotateY(-15deg);
    opacity: 1;
  }
  to {
    -webkit-transform: perspective(400px) rotateY(90deg);
    transform: perspective(400px) rotateY(90deg);
    opacity: 0;
  }
}
@keyframes flipOutY {
  0% {
    -webkit-transform: perspective(400px);
    transform: perspective(400px);
  }
  30% {
    -webkit-transform: perspective(400px) rotateY(-15deg);
    transform: perspective(400px) rotateY(-15deg);
    opacity: 1;
  }
  to {
    -webkit-transform: perspective(400px) rotateY(90deg);
    transform: perspective(400px) rotateY(90deg);
    opacity: 0;
  }
}
.flipOutY {
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
  -webkit-animation-name: flipOutY;
  animation-name: flipOutY;
}

@-webkit-keyframes lightSpeedIn {
  0% {
    -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);
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes lightSpeedIn {
  0% {
    -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);
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.lightSpeedIn {
  -webkit-animation-name: lightSpeedIn;
  animation-name: lightSpeedIn;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

@-webkit-keyframes lightSpeedOut {
  0% {
    opacity: 1;
  }
  to {
    -webkit-transform: translate3d(100%, 0, 0) skewX(30deg);
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
}
@keyframes lightSpeedOut {
  0% {
    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 {
  0% {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate(-200deg);
    transform: rotate(-200deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes rotateIn {
  0% {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate(-200deg);
    transform: rotate(-200deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
.rotateIn {
  -webkit-animation-name: rotateIn;
  animation-name: rotateIn;
}

@-webkit-keyframes rotateInDownLeft {
  0% {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes rotateInDownLeft {
  0% {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
.rotateInDownLeft {
  -webkit-animation-name: rotateInDownLeft;
  animation-name: rotateInDownLeft;
}

@-webkit-keyframes rotateInDownRight {
  0% {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes rotateInDownRight {
  0% {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
.rotateInDownRight {
  -webkit-animation-name: rotateInDownRight;
  animation-name: rotateInDownRight;
}

@-webkit-keyframes rotateInUpLeft {
  0% {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes rotateInUpLeft {
  0% {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
.rotateInUpLeft {
  -webkit-animation-name: rotateInUpLeft;
  animation-name: rotateInUpLeft;
}

@-webkit-keyframes rotateInUpRight {
  0% {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
@keyframes rotateInUpRight {
  0% {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate(-90deg);
    transform: rotate(-90deg);
    opacity: 0;
  }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    opacity: 1;
  }
}
.rotateInUpRight {
  -webkit-animation-name: rotateInUpRight;
  animation-name: rotateInUpRight;
}

@-webkit-keyframes rotateOut {
  0% {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate(200deg);
    transform: rotate(200deg);
    opacity: 0;
  }
}
@keyframes rotateOut {
  0% {
    -webkit-transform-origin: center;
    transform-origin: center;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate(200deg);
    transform: rotate(200deg);
    opacity: 0;
  }
}
.rotateOut {
  -webkit-animation-name: rotateOut;
  animation-name: rotateOut;
}

@-webkit-keyframes rotateOutDownLeft {
  0% {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    opacity: 0;
  }
}
@keyframes rotateOutDownLeft {
  0% {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    opacity: 0;
  }
}
.rotateOutDownLeft {
  -webkit-animation-name: rotateOutDownLeft;
  animation-name: rotateOutDownLeft;
}

@-webkit-keyframes rotateOutDownRight {
  0% {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    opacity: 0;
  }
}
@keyframes rotateOutDownRight {
  0% {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    opacity: 0;
  }
}
.rotateOutDownRight {
  -webkit-animation-name: rotateOutDownRight;
  animation-name: rotateOutDownRight;
}

@-webkit-keyframes rotateOutUpLeft {
  0% {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    opacity: 0;
  }
}
@keyframes rotateOutUpLeft {
  0% {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    opacity: 0;
  }
}
.rotateOutUpLeft {
  -webkit-animation-name: rotateOutUpLeft;
  animation-name: rotateOutUpLeft;
}

@-webkit-keyframes rotateOutUpRight {
  0% {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    opacity: 0;
  }
}
@keyframes rotateOutUpRight {
  0% {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    opacity: 1;
  }
  to {
    -webkit-transform-origin: right bottom;
    transform-origin: right bottom;
    -webkit-transform: rotate(90deg);
    transform: rotate(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: rotate(80deg);
    transform: rotate(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: rotate(60deg);
    transform: rotate(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: rotate(80deg);
    transform: rotate(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: rotate(60deg);
    transform: rotate(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 {
  0% {
    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 {
  0% {
    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;
}

@-webkit-keyframes rollIn {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate(-120deg);
    transform: translate3d(-100%, 0, 0) rotate(-120deg);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes rollIn {
  0% {
    opacity: 0;
    -webkit-transform: translate3d(-100%, 0, 0) rotate(-120deg);
    transform: translate3d(-100%, 0, 0) rotate(-120deg);
  }
  to {
    opacity: 1;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.rollIn {
  -webkit-animation-name: rollIn;
  animation-name: rollIn;
}

@-webkit-keyframes rollOut {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate(120deg);
    transform: translate3d(100%, 0, 0) rotate(120deg);
  }
}
@keyframes rollOut {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    -webkit-transform: translate3d(100%, 0, 0) rotate(120deg);
    transform: translate3d(100%, 0, 0) rotate(120deg);
  }
}
.rollOut {
  -webkit-animation-name: rollOut;
  animation-name: rollOut;
}

@-webkit-keyframes zoomIn {
  0% {
    opacity: 0;
    -webkit-transform: scale3d(0.3, 0.3, 0.3);
    transform: scale3d(0.3, 0.3, 0.3);
  }
  50% {
    opacity: 1;
  }
}
@keyframes zoomIn {
  0% {
    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 {
  0% {
    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 {
  0% {
    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 {
  0% {
    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 {
  0% {
    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 {
  0% {
    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 {
  0% {
    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 {
  0% {
    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 {
  0% {
    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 {
  0% {
    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 {
  0% {
    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 {
  0% {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible;
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes slideInDown {
  0% {
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
    visibility: visible;
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.slideInDown {
  -webkit-animation-name: slideInDown;
  animation-name: slideInDown;
}

@-webkit-keyframes slideInLeft {
  0% {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes slideInLeft {
  0% {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.slideInLeft {
  -webkit-animation-name: slideInLeft;
  animation-name: slideInLeft;
}

@-webkit-keyframes slideInRight {
  0% {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes slideInRight {
  0% {
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.slideInRight {
  -webkit-animation-name: slideInRight;
  animation-name: slideInRight;
}

@-webkit-keyframes slideInUp {
  0% {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
@keyframes slideInUp {
  0% {
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }
  to {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}
.slideInUp {
  -webkit-animation-name: slideInUp;
  animation-name: slideInUp;
}

@-webkit-keyframes slideOutDown {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, 100%, 0);
    transform: translate3d(0, 100%, 0);
  }
}
@keyframes slideOutDown {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(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 {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
}
@keyframes slideOutLeft {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(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 {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(100%, 0, 0);
    transform: translate3d(100%, 0, 0);
  }
}
@keyframes slideOutRight {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(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 {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}
@keyframes slideOutUp {
  0% {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  to {
    visibility: hidden;
    -webkit-transform: translate3d(0, -100%, 0);
    transform: translate3d(0, -100%, 0);
  }
}
.slideOutUp {
  -webkit-animation-name: slideOutUp;
  animation-name: slideOutUp;
}

.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;
}

.animated.delay-1s {
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
}

.animated.delay-2s {
  -webkit-animation-delay: 2s;
  animation-delay: 2s;
}

.animated.delay-3s {
  -webkit-animation-delay: 3s;
  animation-delay: 3s;
}

.animated.delay-4s {
  -webkit-animation-delay: 4s;
  animation-delay: 4s;
}

.animated.delay-5s {
  -webkit-animation-delay: 5s;
  animation-delay: 5s;
}

.animated.fast {
  -webkit-animation-duration: 0.8s;
  animation-duration: 0.8s;
}

.animated.faster {
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
}

.animated.slow {
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
}

.animated.slower {
  -webkit-animation-duration: 3s;
  animation-duration: 3s;
}

@media (prefers-reduced-motion: reduce), (print) {
  .animated {
    -webkit-animation-duration: 1ms !important;
    animation-duration: 1ms !important;
    -webkit-transition-duration: 1ms !important;
    transition-duration: 1ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important;
  }
}
/*# sourceMappingURL=app.min.css.map */
