/*! ------------------------------------------------
 * Project Name: Axio Coming Soon Template
 * Project Description: Axio - awesome coming soon template to kick-start your project
 * Tags: mix_design, axio, coming soon, under construction, template, coming soon page, html5, css3
 * Version: 4.0.2
 * Build Date: April 2017
 * Last Update: December 2024
 * This product is available exclusively on Themeforest
 * Author: mix_design
 * Author URI: https://themeforest.net/user/mix_design
 * File name: main.css
 * ------------------------------------------------
 *
 * ------------------------------------------------
 * Table of Contents
 * ------------------------------------------------
 *  1. Template Backgrounds
 *  2. Fonts
 *  3. Base CSS Styles
 *  4. Animated Headline
 *  5. Loading Animation
 *  6. Typography
 *  7. Buttons & Triggers
 *  8. Forms and Forms Reply Groups
 *  9. Animated Backgrounds
 *  10. Main Section
 *  11. Menu Styles
 *  12. Socials Styles
 *  13. Countdown Styles
 *  14. Popup Dialogs
 *  15. Content Sections
 *  16. Features
 *  17. Google Map
 *  18. Gallery Custom Styles
 * ------------------------------------------------
 * Table of Contents End
 * ------------------------------------------------ */
/* ------------------------------------------------*/
/* Template Backgrounds Start */
/* ------------------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&display=swap");


/* ------------------------------------------------*/
/* Template Backgrounds End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Fonts Start */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Fonts End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Base CSS Styles Start */
/* ------------------------------------------------*/
*, *::before, *::after {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
}
body{
	outline: none !important;
}
button:focus,
button:active,
.btn:focus,
.btn:active,
a:focus,
a:active,
input:focus,
textarea:focus,
select:focus {
    outline: none !important;
    box-shadow: none !important;
}
b{
	font-weight:800;
}
.inline{
	display:inline-block;
}
.vm{
	vertical-align: middle;
}
.vt{
	vertical-align: top;
}
.fw{ color:#ffffff; }
.color0{ color:#c3c3c3; }
.color1{ color:#ff1644; }
.color2{ color:#131313; }
.color3{ color:#c3c3c3; }
.color-sum{ color:#4bccc1; }
.color-min{ color:#ff939e; }

.f8{ font-size:8px !important; }
.f10{ font-size:10px !important; }
.f12{ font-size:12px !important; }
.f14{ font-size:14px !important; }
.f16{ font-size:16px !important; }
.f18{ font-size:18px !important; }
.f22{ font-size:22px !important; }
.f24{ font-size:24px !important; }
.f28{ font-size:28px !important; }
.f38{ font-size:38px !important; }
.f52{ font-size:52px !important; }

.l100{ line-height:100%; }
.l120{ line-height:120%; }
.l140{ line-height:140%; }

.alpha10{ opacity:.1; }
.alpha20{ opacity:.2; }
.alpha30{ opacity:.3; }
.alpha40{ opacity:.4; }
.alpha50{ opacity:.5; }
.alpha60{ opacity:.6; }
.alpha70{ opacity:.7; }
.alpha80{ opacity:.8; }
.alpha90{ opacity:.9; }
.alpha100{ opacity:1; }

.sp-2{ padding:2px; }

.sb-5{ margin-bottom:5px; }

.tc{ text-align:center; }
.tl{ text-align:left; }
.tr{ text-align:right; }
.w-100{ width:100%; }
.relative{ position:relative; }
.absolute{ position:absolute; }
.box{
	width:100%;
	height:100%;
	padding:10px;
	border-radius:20px;
	box-shadow: 0 0px 10px 0 rgba(34, 41, 47, 0.1);
}
.box2{
	width:100%;
	height:100%;
	padding:4px;
	border-radius:10px;
	box-shadow: 0 0px 10px 0 rgba(34, 41, 47, 0.1);
}
.box-inside{
	padding:4px;
}
.thumb_box{
	width:100%;
	height:100%;
	background-size: 20px 20px;
	background-position: center center;
	background-repeat: no-repeat;
	border-radius:6px;
	background-color:#e5e5e5;
}
.thumb{
	width:100%;
	height:100%;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	border-radius:6px;
}
.relative{
	position:relative;
}
.wh-100{
	width:100%;
	height:100%;
}
.btm{
	padding:7px;
}
.btsize{
	width:31px;
	height:31px;
}
.shadow{
  box-shadow: 0 4px 24px 0 rgba(34, 41, 47, 0.2);
}
.shadow_text{
	text-shadow: 0px 0px 10px rgba(0,0,0,.6);
}
.pointer{
	cursor:pointer;
}
.tag{
	background-color: #e3e3e3;
    padding: 10px;
    border-radius: 8px;
    color: #999999;
}
.fw{ color:#fff; }
.relative{ position:relative; }
.absolute{ position:absolute; }
.b10{
	border-radius:10px;
}
.b20{
	border-radius:20px;
}
.st-5{ margin-top:5px; }
.st-10{ margin-top:10px; }

.sl-5{ margin-left:5px; }
.sl-10{ margin-left:10px; }

.sr-5{ margin-right:5px; }
.sr-10{ margin-right:10px; }

.sb-5{ margin-bottom:5px; }
.sb-10{ margin-bottom:10px; }

.s-1{ padding:10px; }
.s-2{ padding:20px; }
.s-3{ padding:30px; }

.btsize{
	width:31px;
	height:31px;
}
.support_bt_box{
	position:fixed; 
	bottom:10px; 
	right:10px; 
	z-index:999;
}
.support_bt{
	background-size:cover; 
	background-repeat: no-repeat; 
	width:66px; 
	height:60px; 
	border-radius:60px; 
	background-color:#ff1644; 
	border:4px solid #fff; 
	background-position: center center;
}


/* MENU */
.menu_master{
	width:100%;
	height:100%;
	background-color:#131313;
	border-radius:30px;
	color:#fff;
	cursor:pointer;
	transition: background-color .2s ease, color .2s ease;
}
.menu_master_inside{
	padding:10px;
}
.menu_master:not(.menu_master_on):hover{
	background-color:#ffffff;
	color:#444444;
	box-shadow: 0 4px 24px 0 rgba(34, 41, 47, 0.2);
}
.menu_master:not(.menu_master_on):hover span,
.menu_master:not(.menu_master_on):hover b{
	color:#444444;
}
.menu_master_on{
	background-color:#ff1644;
	color:#ffffff;
}
.menu_master_on:hover{
	background-color:#ff1644;
	color:#ffffff;
}

/* ASSETS */

.assets-box{
	background-color: #232323; 
	border:2px solid #232323; 
	border-radius: 20px; 
	height:500px; 
	background-position:center center; 
	background-repeat:no-repeat; 
	background-size:20px 20px; 
}
.assets-inside{
	border-radius:20px; 
	background-position:center center; 
	background-repeat:no-repeat; 
	background-size:contain;
}

.comment-toast{
  background-color: rgba(0,0,0,.6);
  border-radius: 10px;
  padding: 6px 10px;
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  opacity: 0;
  transform: translateY(18px);
  will-change: transform, opacity;
}

.comment-toast img{
  width: 16px;
  height: 16px;
  border-radius: 50%;
  display: inline-block;
}

.comment-toast.enter{
  animation: toastIn 320ms ease-out forwards;
}

.comment-toast.leave{
  animation: toastOut 320ms ease-in forwards;
}

@keyframes toastIn{
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes toastOut{
  from { opacity: 1; transform: translateY(0); }
  to   { opacity: 0; transform: translateY(-10px); }
}

.avatar_thumb_box{
	width:100%;
	background-color: #e9e9e9;
    border-radius: 20px;
    background-repeat: no-repeat;
    background-size: 20px 20px;
    background-position: center center;
}
.avatar_thumb{
	width:100%;
	height:100%;
	border-radius: 20px;
	background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
}

.like-heart-pulse{
  animation: likeHeartPulse 160ms ease-out;
}
@keyframes likeHeartPulse{
  0%   { transform: scale(1); }
  45%  { transform: scale(1.10); }
  100% { transform: scale(1); }
}

/* Container das partículas (fica por cima do coração) */
.like-heart-fx-layer{
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: visible;
}

/* Partícula de coração flutuante */
.like-heart-fx{
  position: absolute;
  width: var(--size, 18px);
  height: var(--size, 18px);
  opacity: 0;
  transform: translate(-50%, -50%);
  will-change: transform, opacity;
  animation: likeHeartFloat var(--dur, 900ms) ease-out forwards;
  filter: drop-shadow(0 2px 2px rgba(0,0,0,.25));
}

@keyframes likeHeartFloat{
  0%{
    opacity: 0;
    transform: translate(-50%, -50%) translate(0, 6px) rotate(0deg) scale(0.85);
  }
  12%{
    opacity: 1;
  }
  100%{
    opacity: 0;
    transform: translate(-50%, -50%)
      translate(var(--dx, 0px), var(--dy, -60px))
      rotate(var(--rot, 10deg))
      scale(1.05);
  }
}

button:active, button:focus {
  outline: none !important;
}

button::-moz-focus-inner {
  border: 0 !important;
}

input::-moz-focus-inner {
  border: 0 !important;
}

.avatar-cropper-wrap{
  width: 100%;
}

.avatar-cropper{
  position: relative;
  width: 100%;
  height: 200px;
  background: #c3c3c3;
  border-radius: 20px;
  overflow: hidden;
  touch-action: none; 
}

.avatar-cropper img{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(1);
  transform-origin: center center;
  user-select: none;
  -webkit-user-drag: none;
  max-width: none;  
  max-height: none;
}

.avatar-overlay{
  position:absolute;
  inset:0;
  pointer-events:none;
}

.avatar-hole{
  position:absolute;
  left:50%;
  top:50%;
  width:140px;
  height:140px;
  transform: translate(-50%, -50%);
  border-radius: 14px;
  box-shadow: 0 0 0 9999px rgba(0,0,0,0.40);

  outline: 2px solid rgba(255,255,255,0.25);
  background: transparent; 
}
.avatar-upload{
  position:absolute;
  right:8px;
  bottom:48px;
}

.avatar-trash{
  position:absolute;
  right:10px;
  bottom:10px;
}

.avatar-zoombar{
  position:absolute;
  left:10px;
  bottom:10px;
}

::-moz-selection {
  background-color: #adafaf;
  color: #fff;
  text-shadow: none;
}

::selection {
  background-color: #adafaf;
  color: #fff;
  text-shadow: none;
}

::-webkit-scrollbar {
  display: none;
  width: 6px;
}
@media only screen and (min-width: 768px) {
  ::-webkit-scrollbar {
    display: block;
  }
}

::-webkit-scrollbar-track {
  border-radius: 20px;
}

::-webkit-scrollbar-thumb {
  border-radius: 10px;
}

html {
  font-family: sans-serif;
  font-size: 62.5%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

html,
body {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

body {
  position: relative;
  min-width: 320px;
  overflow-x: hidden !important;
  font: normal 400 1.4rem/1.7 "Montserrat", sans-serif;
  background-color: #fff;
  color: #313637;
}

section {
  position: relative;
  min-width: 320px;
}

a {
  text-decoration: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  outline: 0;
  color: #313637;
  -webkit-transition: color 0.3s ease-in-out;
  -o-transition: color 0.3s ease-in-out;
  -moz-transition: color 0.3s ease-in-out;
  transition: color 0.3s ease-in-out;
}
a.light {
  color: #fff;
}
.no-touch a:hover {
  color: #6f7273;
}
.no-touch a:hover.light {
  color: #b3b3b3;
}

a:hover,
a:active,
a:focus {
  outline: 0;
}

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

.overflow-hidden {
  overflow: hidden !important;
}

.fullheight {
  position: static;
  height: auto;
}
@media only screen and (min-width: 1200px) {
  .fullheight {
    position: relative;
    height: 100%;
  }
}

.fullheight-mobile {
  position: relative;
  height: 100%;
}

.color-layer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.color-layer-medium {
  background-color: rgba(0, 0, 0, 0.6);
}

.color-layer-dark {
  background-color: rgba(0, 0, 0, 0.8);
}

.bg-light {
  background-color: #fff;
}

.bg-medium {
  background-color: #e6e6e6;
}

.bg-dark {
  background-color: #313637;
}

.calendar-wrapper {
    width: 100%;
}

.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 8px;
}

.calendar-weekday {
    text-align: center;
    font-weight: bold;
    font-size: 13px;
    color: #666;
    padding: 8px 0;
}

.calendar-day {
    min-height: 110px;
    background: #fff;
    border-radius: 14px;
    border: 1px solid #eee;
    padding: 8px;
    overflow: hidden;
}

.calendar-day.empty {
    background: transparent;
    border: none;
}

.calendar-day.past{
    opacity:.6;
    background-color:#f3f3f3;
}

.calendar-day-number {
    display: inline-block;
    min-width: 28px;
    height: 28px;
    line-height: 28px;
    text-align: center;
    border-radius: 50px;
    background: #f1f1f1;
    color: #333;
    font-size: 13px;
    font-weight: bold;
}
.calendar-day-header {
	    display: flex;
	    align-items: center;
	    gap: 5px;
	    margin-bottom: 6px;
	}

	.calendar-note-edit {
	    flex: 0 0 28px;
	    width: 28px;
	    height: 28px;
	    border-radius: 50%;
	    background: #efefef;
	    color: #777;
	    display: flex;
	    align-items: center;
	    justify-content: center;
	    font-size: 12px;
	}

	.calendar-note-label {
	    flex: 1;
	    background: #a0dfdf;
	    color: #555;
	    border-radius: 20px;
	    padding: 6px 8px;
	    font-size: 11px;
	    white-space: nowrap;
	    overflow: hidden;
	    text-overflow: ellipsis;
	}
	.calendar-storytelling-add,
.calendar-medias-add {
    background: #f7f7f7;
    color: #dbdbdb;
    border-radius: 8px;
    padding: 4px 6px;
    margin-top: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.calendar-note-label{
    cursor:pointer;
    transition:all .2s ease;
}

.calendar-note-label.active{
    white-space: normal;
    overflow: visible;
    text-overflow: initial;
}

.calendar-storytelling-label,
.calendar-medias-label {
    background: transparent;
    color: #555;
    margin-top: 4px;
    white-space: nowrap;
    overflow: hidden;
}

.calendar-day.today .calendar-day-number {
    background: #ff1644;
    color: #fff;
}

.calendar-badge {
    display: block;
    font-size: 11px;
    line-height: 1.2;
    padding: 5px 7px;
    border-radius: 20px;
    margin-top: 5px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Mobile */
@media (max-width: 768px) {
    .calendar-grid {
        gap: 5px;
    }

    .calendar-weekday {
        font-size: 11px;
    }

    .calendar-day {
        min-height: 75px;
        padding: 5px;
        border-radius: 10px;
    }

    .calendar-day-number {
        min-width: 22px;
        height: 22px;
        line-height: 22px;
        font-size: 11px;
    }

    .calendar-badge {
        font-size: 9px;
        padding: 4px 5px;
    }
}


/* ------------------------------------------------*/
/* Base CSS Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Loading Animation Start */
/* ------------------------------------------------*/
.section-main .headline__subtitle,
.section-main .headline__title {
  opacity: 0;
  -webkit-transform: translateZ(0);
     -moz-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-transform: translateY(-50px);
     -moz-transform: translateY(-50px);
      -ms-transform: translateY(-50px);
          transform: translateY(-50px);
  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
  transition: opacity 0.3s, -webkit-transform 0.3s;
  -o-transition: opacity 0.3s, transform 0.3s;
  -moz-transition: opacity 0.3s, transform 0.3s, -moz-transform 0.3s;
  transition: opacity 0.3s, transform 0.3s;
  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
.section-main .headline__description,
.section-main .headline__btnholder {
  opacity: 0;
  -webkit-transform: translateZ(0);
     -moz-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-transform: translateY(50px);
     -moz-transform: translateY(50px);
      -ms-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
  transition: opacity 0.3s, -webkit-transform 0.3s;
  -o-transition: opacity 0.3s, transform 0.3s;
  -moz-transition: opacity 0.3s, transform 0.3s, -moz-transform 0.3s;
  transition: opacity 0.3s, transform 0.3s;
  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
.section-main .intro__header .logo,
.section-main .intro__header .menu-trigger {
  opacity: 0;
  -webkit-transition: opacity 1s;
  -o-transition: opacity 1s;
  -moz-transition: opacity 1s;
  transition: opacity 1s;
}
.section-main .intro__countdown {
  opacity: 0;
  -webkit-transition: opacity 1s;
  -o-transition: opacity 1s;
  -moz-transition: opacity 1s;
  transition: opacity 1s;
}
.section-main .intro__copyright {
  opacity: 0;
  -webkit-transition: opacity 1s;
  -o-transition: opacity 1s;
  -moz-transition: opacity 1s;
  transition: opacity 1s;
}
.section-main .aside__content {
  opacity: 0;
  -webkit-transition: opacity 1s ease-in-out;
  -o-transition: opacity 1s ease-in-out;
  -moz-transition: opacity 1s ease-in-out;
  transition: opacity 1s ease-in-out;
}
.section-main .aside__content.animate-out {
  opacity: 0;
  -webkit-transition: opacity 0.5s ease-in-out;
  -o-transition: opacity 0.5s ease-in-out;
  -moz-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out;
}
.section-main .aside__socials {
  opacity: 0;
  -webkit-transition: opacity 1s;
  -o-transition: opacity 1s;
  -moz-transition: opacity 1s;
  transition: opacity 1s;
}
.section-main.loaded .headline__subtitle,
.section-main.loaded .headline__title,
.section-main.loaded .headline__description,
.section-main.loaded .headline__btnholder {
  opacity: 1;
  -webkit-transform: translateY(0);
     -moz-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}
.section-main.loaded .headline__subtitle {
  -webkit-transition: opacity 0.6s 0s, -webkit-transform 0.6s 0s;
  transition: opacity 0.6s 0s, -webkit-transform 0.6s 0s;
  -o-transition: transform 0.6s 0s, opacity 0.6s 0s;
  -moz-transition: transform 0.6s 0s, opacity 0.6s 0s, -moz-transform 0.6s 0s;
  transition: transform 0.6s 0s, opacity 0.6s 0s;
  transition: transform 0.6s 0s, opacity 0.6s 0s, -webkit-transform 0.6s 0s, -moz-transform 0.6s 0s;
}
.section-main.loaded .headline__title {
  -webkit-transition: opacity 0.6s 0s, -webkit-transform 0.6s 0s;
  transition: opacity 0.6s 0s, -webkit-transform 0.6s 0s;
  -o-transition: transform 0.6s 0s, opacity 0.6s 0s;
  -moz-transition: transform 0.6s 0s, opacity 0.6s 0s, -moz-transform 0.6s 0s;
  transition: transform 0.6s 0s, opacity 0.6s 0s;
  transition: transform 0.6s 0s, opacity 0.6s 0s, -webkit-transform 0.6s 0s, -moz-transform 0.6s 0s;
}
.section-main.loaded .headline__description {
  -webkit-transition: opacity 0.6s 0s, -webkit-transform 0.6s 0s;
  transition: opacity 0.6s 0s, -webkit-transform 0.6s 0s;
  -o-transition: transform 0.6s 0s, opacity 0.6s 0s;
  -moz-transition: transform 0.6s 0s, opacity 0.6s 0s, -moz-transform 0.6s 0s;
  transition: transform 0.6s 0s, opacity 0.6s 0s;
  transition: transform 0.6s 0s, opacity 0.6s 0s, -webkit-transform 0.6s 0s, -moz-transform 0.6s 0s;
}
.section-main.loaded .headline__btnholder {
  -webkit-transition: opacity 0.6s 0s, background-color 0.3s, color 0.3s, -webkit-transform 0.6s 0s;
  transition: opacity 0.6s 0s, background-color 0.3s, color 0.3s, -webkit-transform 0.6s 0s;
  -o-transition: transform 0.6s 0s, opacity 0.6s 0s, background-color 0.3s, color 0.3s;
  -moz-transition: transform 0.6s 0s, opacity 0.6s 0s, background-color 0.3s, color 0.3s, -moz-transform 0.6s 0s;
  transition: transform 0.6s 0s, opacity 0.6s 0s, background-color 0.3s, color 0.3s;
  transition: transform 0.6s 0s, opacity 0.6s 0s, background-color 0.3s, color 0.3s, -webkit-transform 0.6s 0s, -moz-transform 0.6s 0s;
}
.section-main.loaded .intro__header .logo,
.section-main.loaded .intro__header .menu-trigger {
  opacity: 1;
}
.section-main.loaded .intro__countdown {
  opacity: 1;
}
.section-main.loaded .intro__copyright {
  opacity: 1;
}
.section-main.loaded .aside__content {
  opacity: 1;
}
.section-main.loaded .aside__content.animate-out {
  opacity: 0;
  -webkit-transition: opacity 0.5s ease-in-out;
  -o-transition: opacity 0.5s ease-in-out;
  -moz-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out;
}
.section-main.loaded .aside__socials {
  opacity: 1;
}
@media only screen and (min-width: 1200px) {
  .section-main .menu {
    opacity: 0;
    -webkit-transition: opacity 1s;
    -o-transition: opacity 1s;
    -moz-transition: opacity 1s;
    transition: opacity 1s;
  }
  .section-main.loaded .menu {
    opacity: 1;
  }
}

/* ------------------------------------------------*/
/* Loading Animation End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Animated Headline Start */
/* ------------------------------------------------*/
.words-wrapper {
  display: inline-block;
  position: relative;
  text-align: left;
}
.words-wrapper b {
  display: inline-block;
  position: absolute;
  white-space: nowrap;
  left: 0;
  top: 0;
}
.words-wrapper b.is-visible {
  position: relative;
}
.no-js .words-wrapper b {
  opacity: 0;
}
.no-js .words-wrapper b.is-visible {
  opacity: 1;
}

.clip span {
  display: inline-block;
}
.clip .words-wrapper {
  overflow: hidden;
  vertical-align: top;
  padding-right: 10px;
}
.clip .words-wrapper::after {
  content: "";
  position: absolute;
  top: 10%;
  right: 0;
  width: 6px;
  height: 80%;
  -moz-border-radius: 1px;
       border-radius: 1px;
  background-color: #5a5e5f;
}
.clip b {
  opacity: 0;
}
.clip b.is-visible {
  opacity: 1;
}
@media only screen and (min-width: 1400px) {
  .clip .words-wrapper {
    padding-right: 14px;
  }
  .clip .words-wrapper::after {
    width: 8px;
  }
}

/* ------------------------------------------------*/
/* Animated Headline End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Animated Backgrounds Start */
/* ------------------------------------------------*/
.video-background {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

#video-wrapper {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: transparent;
}

#main-video {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: transparent;
  background-position: center center;
  -moz-background-size: contain;
       background-size: contain;
  -o-object-fit: cover;
     object-fit: cover;
}

#bgndKenburns,
#bgndKenburns-c1,
#bgndKenburns-c2,
#bgndKenburns-c3,
#bgndKenburns-mono {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  background-color: transparent;
}

#particles-js,
#polygons-js,
#stars-js {
  position: absolute;
  width: 100%;
  height: 100%;
  min-height: 320px;
  background-color: transparent;
}

#sparkles {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  min-height: 320px;
  background-color: transparent;
  overflow: hidden;
}
#sparkles .layer {
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-transform: translateZ(0);
     -moz-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-backface-visibility: hidden;
     -moz-backface-visibility: hidden;
          backface-visibility: hidden;
  will-change: transform;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  -o-transition: transform 0.3s;
  -moz-transition: transform 0.3s, -moz-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
#sparkles .layer img {
  position: absolute;
  left: 50%;
  top: 50%;
  bottom: auto;
  right: auto;
  -webkit-transform: translateX(-50%) translateY(-50%);
     -moz-transform: translateX(-50%) translateY(-50%);
      -ms-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
  width: 100%;
  height: auto;
}
#sparkles .layer.layer-1 {
  -webkit-animation: sparkles-1 4s infinite;
     -moz-animation: sparkles-1 4s infinite;
          animation: sparkles-1 4s infinite;
}
#sparkles .layer.layer-2 {
  -webkit-animation: sparkles-2 20s infinite;
     -moz-animation: sparkles-2 20s infinite;
          animation: sparkles-2 20s infinite;
  -webkit-animation-timing-function: ease-in-out;
     -moz-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
}
#sparkles .layer.layer-3 {
  -webkit-animation: sparkles-3 8s infinite;
     -moz-animation: sparkles-3 8s infinite;
          animation: sparkles-3 8s infinite;
  -webkit-animation-timing-function: ease-in-out;
     -moz-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
}
#sparkles .layer.layer-4 {
  -webkit-animation: sparkles-4 6s infinite;
     -moz-animation: sparkles-4 6s infinite;
          animation: sparkles-4 6s infinite;
  -webkit-animation-timing-function: ease-in-out;
     -moz-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
}
@media only screen and (min-width: 992px) {
  #sparkles .layer img {
    bottom: 0;
    left: auto;
    top: auto;
    -webkit-transform: translateX(0) translateY(0);
       -moz-transform: translateX(0) translateY(0);
        -ms-transform: translateX(0) translateY(0);
            transform: translateX(0) translateY(0);
  }
}

@-webkit-keyframes sparkles-1 {
  0% {
    opacity: 1;
    -webkit-transform: translateX(0) translateY(0);
            transform: translateX(0) translateY(0);
  }
  25% {
    opacity: 0.2;
    -webkit-transform: translateX(-10px) translateY(10px);
            transform: translateX(-10px) translateY(10px);
  }
  50% {
    opacity: 0.2;
    -webkit-transform: translateX(-5px) translateY(15px);
            transform: translateX(-5px) translateY(15px);
  }
  75% {
    opacity: 0.4;
    -webkit-transform: translateX(7px) translateY(5px);
            transform: translateX(7px) translateY(5px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0) translateY(0);
            transform: translateX(0) translateY(0);
  }
}

@-moz-keyframes sparkles-1 {
  0% {
    opacity: 1;
    -moz-transform: translateX(0) translateY(0);
         transform: translateX(0) translateY(0);
  }
  25% {
    opacity: 0.2;
    -moz-transform: translateX(-10px) translateY(10px);
         transform: translateX(-10px) translateY(10px);
  }
  50% {
    opacity: 0.2;
    -moz-transform: translateX(-5px) translateY(15px);
         transform: translateX(-5px) translateY(15px);
  }
  75% {
    opacity: 0.4;
    -moz-transform: translateX(7px) translateY(5px);
         transform: translateX(7px) translateY(5px);
  }
  100% {
    opacity: 1;
    -moz-transform: translateX(0) translateY(0);
         transform: translateX(0) translateY(0);
  }
}

@keyframes sparkles-1 {
  0% {
    opacity: 1;
    -webkit-transform: translateX(0) translateY(0);
       -moz-transform: translateX(0) translateY(0);
            transform: translateX(0) translateY(0);
  }
  25% {
    opacity: 0.2;
    -webkit-transform: translateX(-10px) translateY(10px);
       -moz-transform: translateX(-10px) translateY(10px);
            transform: translateX(-10px) translateY(10px);
  }
  50% {
    opacity: 0.2;
    -webkit-transform: translateX(-5px) translateY(15px);
       -moz-transform: translateX(-5px) translateY(15px);
            transform: translateX(-5px) translateY(15px);
  }
  75% {
    opacity: 0.4;
    -webkit-transform: translateX(7px) translateY(5px);
       -moz-transform: translateX(7px) translateY(5px);
            transform: translateX(7px) translateY(5px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0) translateY(0);
       -moz-transform: translateX(0) translateY(0);
            transform: translateX(0) translateY(0);
  }
}
@-webkit-keyframes sparkles-2 {
  0% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(0) scale(1.2);
            transform: translateX(0) translateY(0) scale(1.2);
  }
  25% {
    opacity: 1;
  }
  99% {
    opacity: 0;
    -webkit-transform: translateX(-10px) translateY(-120px) scale(1);
            transform: translateX(-10px) translateY(-120px) scale(1);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(0) scale(1.2);
            transform: translateX(0) translateY(0) scale(1.2);
  }
}
@-moz-keyframes sparkles-2 {
  0% {
    opacity: 0;
    -moz-transform: translateX(0) translateY(0) scale(1.2);
         transform: translateX(0) translateY(0) scale(1.2);
  }
  25% {
    opacity: 1;
  }
  99% {
    opacity: 0;
    -moz-transform: translateX(-10px) translateY(-120px) scale(1);
         transform: translateX(-10px) translateY(-120px) scale(1);
  }
  100% {
    opacity: 0;
    -moz-transform: translateX(0) translateY(0) scale(1.2);
         transform: translateX(0) translateY(0) scale(1.2);
  }
}
@keyframes sparkles-2 {
  0% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(0) scale(1.2);
       -moz-transform: translateX(0) translateY(0) scale(1.2);
            transform: translateX(0) translateY(0) scale(1.2);
  }
  25% {
    opacity: 1;
  }
  99% {
    opacity: 0;
    -webkit-transform: translateX(-10px) translateY(-120px) scale(1);
       -moz-transform: translateX(-10px) translateY(-120px) scale(1);
            transform: translateX(-10px) translateY(-120px) scale(1);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(0) scale(1.2);
       -moz-transform: translateX(0) translateY(0) scale(1.2);
            transform: translateX(0) translateY(0) scale(1.2);
  }
}
@-webkit-keyframes sparkles-3 {
  0% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(0) scale(1);
            transform: translateX(0) translateY(0) scale(1);
  }
  25% {
    opacity: 1;
  }
  99% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(-80px) scale(1.6);
            transform: translateX(0) translateY(-80px) scale(1.6);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(0) scale(1);
            transform: translateX(0) translateY(0) scale(1);
  }
}
@-moz-keyframes sparkles-3 {
  0% {
    opacity: 0;
    -moz-transform: translateX(0) translateY(0) scale(1);
         transform: translateX(0) translateY(0) scale(1);
  }
  25% {
    opacity: 1;
  }
  99% {
    opacity: 0;
    -moz-transform: translateX(0) translateY(-80px) scale(1.6);
         transform: translateX(0) translateY(-80px) scale(1.6);
  }
  100% {
    opacity: 0;
    -moz-transform: translateX(0) translateY(0) scale(1);
         transform: translateX(0) translateY(0) scale(1);
  }
}
@keyframes sparkles-3 {
  0% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(0) scale(1);
       -moz-transform: translateX(0) translateY(0) scale(1);
            transform: translateX(0) translateY(0) scale(1);
  }
  25% {
    opacity: 1;
  }
  99% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(-80px) scale(1.6);
       -moz-transform: translateX(0) translateY(-80px) scale(1.6);
            transform: translateX(0) translateY(-80px) scale(1.6);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateX(0) translateY(0) scale(1);
       -moz-transform: translateX(0) translateY(0) scale(1);
            transform: translateX(0) translateY(0) scale(1);
  }
}
@-webkit-keyframes sparkles-4 {
  0% {
    opacity: 0.4;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  25% {
    opacity: 1;
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
  75% {
    opacity: 0.6;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  100% {
    opacity: 0.4;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@-moz-keyframes sparkles-4 {
  0% {
    opacity: 0.4;
    -moz-transform: scale(1);
         transform: scale(1);
  }
  25% {
    opacity: 1;
    -moz-transform: scale(1.05);
         transform: scale(1.05);
  }
  75% {
    opacity: 0.6;
    -moz-transform: scale(1);
         transform: scale(1);
  }
  100% {
    opacity: 0.4;
    -moz-transform: scale(1);
         transform: scale(1);
  }
}
@keyframes sparkles-4 {
  0% {
    opacity: 0.4;
    -webkit-transform: scale(1);
       -moz-transform: scale(1);
            transform: scale(1);
  }
  25% {
    opacity: 1;
    -webkit-transform: scale(1.05);
       -moz-transform: scale(1.05);
            transform: scale(1.05);
  }
  75% {
    opacity: 0.6;
    -webkit-transform: scale(1);
       -moz-transform: scale(1);
            transform: scale(1);
  }
  100% {
    opacity: 0.4;
    -webkit-transform: scale(1);
       -moz-transform: scale(1);
            transform: scale(1);
  }
}
#clouds {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  min-height: 320px;
  background-color: transparent;
  overflow: hidden;
}
#clouds .clouds__layer {
  position: absolute;
  top: 0;
  left: 100%;
  width: 100%;
  height: 100%;
  -webkit-transform: translateZ(0);
     -moz-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-backface-visibility: hidden;
     -moz-backface-visibility: hidden;
          backface-visibility: hidden;
  will-change: transform;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  -o-transition: transform 0.3s;
  -moz-transition: transform 0.3s, -moz-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
#clouds .clouds__layer img {
  display: block;
  height: auto;
  outline: none;
}
#clouds .clouds__layer1 {
  width: 400px;
  -webkit-animation: clouds-1 60s infinite;
     -moz-animation: clouds-1 60s infinite;
          animation: clouds-1 60s infinite;
  -webkit-animation-timing-function: ease-in;
     -moz-animation-timing-function: ease-in;
          animation-timing-function: ease-in;
}
#clouds .clouds__layer1 img {
  position: absolute;
  bottom: -100px;
  left: 0;
  width: 400px;
}
#clouds .clouds__layer2 {
  width: 560px;
  -webkit-animation: clouds-1 infinite;
     -moz-animation: clouds-1 infinite;
          animation: clouds-1 infinite;
  -webkit-animation-duration: 43s;
     -moz-animation-duration: 43s;
          animation-duration: 43s;
  -webkit-animation-timing-function: ease-in;
     -moz-animation-timing-function: ease-in;
          animation-timing-function: ease-in;
}
#clouds .clouds__layer2 img {
  position: absolute;
  top: -60px;
  left: 0;
  width: 560px;
}
#clouds .clouds__layer3 {
  width: 300px;
  -webkit-animation: clouds-1 infinite;
     -moz-animation: clouds-1 infinite;
          animation: clouds-1 infinite;
  -webkit-animation-duration: 51s;
     -moz-animation-duration: 51s;
          animation-duration: 51s;
  -webkit-animation-delay: 10s;
     -moz-animation-delay: 10s;
          animation-delay: 10s;
  -webkit-animation-timing-function: ease-in;
     -moz-animation-timing-function: ease-in;
          animation-timing-function: ease-in;
}
#clouds .clouds__layer3 img {
  width: 300px;
  position: absolute;
  top: 180px;
  left: 0;
}

@-webkit-keyframes clouds-1 {
  0% {
    opacity: 1;
    left: 100%;
  }
  98% {
    opacity: 1;
    left: -100%;
  }
  99% {
    opacity: 0;
    left: -100%;
  }
  100% {
    opacity: 0;
    left: 100%;
  }
}

@-moz-keyframes clouds-1 {
  0% {
    opacity: 1;
    left: 100%;
  }
  98% {
    opacity: 1;
    left: -100%;
  }
  99% {
    opacity: 0;
    left: -100%;
  }
  100% {
    opacity: 0;
    left: 100%;
  }
}

@keyframes clouds-1 {
  0% {
    opacity: 1;
    left: 100%;
  }
  98% {
    opacity: 1;
    left: -100%;
  }
  99% {
    opacity: 0;
    left: -100%;
  }
  100% {
    opacity: 0;
    left: 100%;
  }
}
/* ------------------------------------------------*/
/* Animated Backgrounds End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Typography Start */
/* ------------------------------------------------*/
h1 {
  font: normal 700 6rem "Montserrat", sans-serif;
  letter-spacing: -0.1rem;
  color: #fff;
}
@media only screen and (min-width: 768px) {
  h1 {
    font-size: 13rem;
  }
}
@media only screen and (min-width: 1400px) {
  h1 {
    font-size: 13rem;
  }
}

.headline__subtitle {
  font: normal 400 1.6rem/1.2 "Montserrat", sans-serif;
  color: #fff;
  padding-left: 0.2rem;
}
@media only screen and (min-width: 768px) {
  .headline__subtitle {
    font-size: 2.4rem;
    margin-bottom: -0.6rem;
  }
}
@media only screen and (min-width: 1200px) {
  .headline__subtitle {
    margin-top: 2rem;
  }
}
@media only screen and (min-width: 1400px) {
  .headline__subtitle {
    font-size: 3rem;
  }
}

.headline__description {
  font: normal 400 1.4rem/1.7 "Montserrat", sans-serif;
  color: #fff;
  padding-left: 0.2rem;
  max-width: 500px;
  margin-top: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .headline__description {
    font-size: 1.6rem;
    margin-top: 1.6rem;
  }
}
@media only screen and (min-width: 1400px) {
  .headline__description {
    max-width: 610px;
    font-size: 2rem;
  }
}

.headline__btnholder {
  margin-top: 3.6rem;
}
@media only screen and (min-width: 768px) {
  .headline__btnholder {
    margin-top: 3.8rem;
  }
}
@media only screen and (min-width: 1400px) {
  .headline__btnholder {
    margin-top: 4.6rem;
  }
}

h2 {
  position: relative;
  display: inline-block;
  font: normal 700 5rem/1 "Montserrat", sans-serif;
  letter-spacing: -0.14rem;
  color: #adafaf;
  padding-bottom: 0.4rem;
}
h2::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: -3rem;
  width: -moz-calc(100% + 3rem);
  width: calc(100% + 3rem);
  height: 6px;
  background-color: #6f7273;
  -moz-border-radius: 1px;
       border-radius: 1px;
}
@media only screen and (min-width: 768px) {
  h2 {
    font-size: 8.6rem;
  }
  h2::after {
    left: -5rem;
    width: -moz-calc(100% + 5rem);
    width: calc(100% + 5rem);
  }
}
@media only screen and (min-width: 1400px) {
  h2 {
    font-size: 12rem;
  }
  h2::after {
    left: -6rem;
    width: -moz-calc(100% + 6rem);
    width: calc(100% + 6rem);
  }
}

h3 {
  font: normal 700 1.6rem/1.4 "Montserrat", sans-serif;
  text-transform: uppercase;
  color: #1d2021;
  margin-bottom: 1.8rem;
}
h3.light {
  color: #fff;
}
@media only screen and (min-width: 1400px) {
  h3 {
    font-size: 2rem;
  }
}

h4 {
  font: normal 700 1.5rem/1.2 "Montserrat", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: #313637;
}
h4.light {
  color: #fff;
}
h4 small {
  display: block;
  margin-top: 0.2rem;
  font: italic 400 1.3rem/1.2 "Montserrat", sans-serif;
  text-transform: none;
}
@media only screen and (min-width: 1400px) {
  h4 {
    font-size: 1.9rem;
  }
  h4 small {
    font-size: 1.4rem;
  }
}

p {
  font: normal 400 1.6rem/1.7 "Montserrat", sans-serif;
  color: #313637;
}
p.light {
  color: #fff;
}
p.copyright {
  font: normal 500 1.1rem/1 "Montserrat", sans-serif;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
  letter-spacing: 0.03em;
}
p.copyright a {
  color: #fff;
  -webkit-transition: color 0.3s ease-in-out;
  -o-transition: color 0.3s ease-in-out;
  -moz-transition: color 0.3s ease-in-out;
  transition: color 0.3s ease-in-out;
}
.no-touch p.copyright a:hover {
  color: rgba(255, 255, 255, 0.6);
}

.inner__text {
  font: normal 500 1.6rem/1.7 "Montserrat", sans-serif;
  margin-top: 3rem;
  padding-left: 2px;
}
.inner__text span {
  font-weight: 700;
  white-space: nowrap;
}
@media only screen and (min-width: 1400px) {
  .inner__text {
    font-size: 2rem;
  }
}

.aside__title {
  font: normal 700 2rem/1.4 "Montserrat", sans-serif;
  color: #fff;
  max-width: 500px;
  margin-bottom: 2.4rem;
}
@media only screen and (min-width: 1400px) {
  .aside__title {
    font-size: 2.6rem;
  }
}

.aside__text {
  font: normal 400 1.4rem/1.7 "Montserrat", sans-serif;
  color: #fff;
  max-width: 500px;
  margin-bottom: 3.2rem;
}
@media only screen and (min-width: 1400px) {
  .aside__text {
    font-size: 1.6rem;
    margin-bottom: 3.4rem;
  }
}

blockquote {
  position: relative;
  text-align: center;
}
blockquote i {
  display: block;
  font-size: 3rem;
  line-height: 1.2;
  color: #313637;
  margin: 0 auto 3.6rem;
}
blockquote i.light {
  color: #fff;
}
blockquote p {
  font: italic 500 2rem/1.4 "Montserrat", sans-serif;
  color: #1d2021;
  margin-bottom: 3rem;
}
blockquote p.light {
  color: #fff;
}
blockquote cite {
  font: normal 400 1.4rem/1.2 "Montserrat", sans-serif;
  color: rgba(49, 54, 55, 0.8);
}
blockquote cite.light {
  color: rgba(255, 255, 255, 0.8);
}
blockquote cite span {
  display: block;
}
@media only screen and (min-width: 768px) {
  blockquote p {
    max-width: 560px;
    margin: 0 auto 3rem;
  }
}
@media only screen and (min-width: 1400px) {
  blockquote p {
    max-width: 760px;
    font-size: 3rem;
  }
}

.popup__title {
  font: normal 700 2.6rem/1.4 "Montserrat", sans-serif;
  color: #313637;
  margin-bottom: 2rem;
}
.popup__title.light {
  color: #fff;
}
@media only screen and (min-width: 1200px) {
  .popup__title {
    font-size: 2rem;
  }
}
@media only screen and (min-width: 1400px) {
  .popup__title {
    font-size: 2.6rem;
  }
}

.popup__subtitle {
  font: normal 400 1.6rem/1.7 "Montserrat", sans-serif;
  color: #313637;
}
.popup__subtitle.light {
  color: #fff;
}
@media only screen and (min-width: 1400px) {
  .popup__subtitle {
    font-size: 1.6rem;
  }
}

/* ------------------------------------------------*/
/* Typography End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Buttons & Triggers Start */
/* ------------------------------------------------*/
.menu-trigger {
  display: block;
  position: absolute;
  top: 0;
  right: 3rem;
  width: 46px;
  height: 46px;
  border: 1px solid #fff;
  -moz-border-radius: 4px;
       border-radius: 4px;
}
.menu-trigger i {
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  bottom: auto;
  right: auto;
  -webkit-transform: translateX(-50%) translateY(-50%);
     -moz-transform: translateX(-50%) translateY(-50%);
      -ms-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
  color: #fff;
  font-size: 2rem;
}
@media only screen and (min-width: 768px) {
  .menu-trigger {
    right: 5rem;
  }
}
@media only screen and (min-width: 1200px) {
  .menu-trigger {
    display: none;
  }
}

.menu-close {
  display: inline-block;
  position: relative;
  width: 46px;
  height: 46px;
  border: 2px solid gray;
  -moz-border-radius: 4px;
       border-radius: 4px;
}
.menu-close i {
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  bottom: auto;
  right: auto;
  -webkit-transform: translateX(-50%) translateY(-50%);
     -moz-transform: translateX(-50%) translateY(-50%);
      -ms-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
  color: #b3b3b3;
  font-size: 1.8rem;
}

.section-close {
  -webkit-transform: scale(0);
     -moz-transform: scale(0);
      -ms-transform: scale(0);
          transform: scale(0);
  -webkit-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.section-close.is-scaled-up {
  -webkit-transform: scale(1);
     -moz-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}

.button {
  position: relative;
  display: inline-block;
  border: none;
  outline: none;
  background-color: transparent;
  padding: 1.2rem 3.2rem;
  font: normal 700 1.4rem/1.7 "Montserrat", sans-serif;
  color: #fff;
  -moz-border-radius: 4px;
       border-radius: 4px;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  -webkit-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
@media only screen and (min-width: 768px) {
  .button {
    padding: 1.4rem 3.2rem;
  }
}
@media only screen and (min-width: 1400px) {
  .button {
    padding: 1.6rem 3.8rem;
    font-size: 1.4rem;
  }
}

.button-square {
  position: relative;
  display: block;
  border: none;
  outline: none;
  width: 46px;
  height: 46px;
  background-color: transparent;
  -moz-border-radius: 4px;
       border-radius: 4px;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  -webkit-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.button-square.is-scaled-up {
  -webkit-transform: scale(1);
     -moz-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}
.button-square i {
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  bottom: auto;
  right: auto;
  -webkit-transform: translateX(-50%) translateY(-50%);
     -moz-transform: translateX(-50%) translateY(-50%);
      -ms-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
  font-size: 1.8rem;
}

.button-solid-light {
  background-color: #adafaf;
  border: 2px solid #adafaf;
  color: #191b1c;
}
.no-touch .button-solid-light:hover {
  background-color: #adafaf;
  border: 2px solid #adafaf;
}

.button-solid-dark {
  background-color: #313637;
  border: 2px solid #313637;
  color: #fff;
}
.no-touch .button-solid-dark:hover {
  background-color: transparent;
  border: 2px solid #adafaf;
  color: #313637;
}

.button-outline-light {
  background-color: transparent;
  color: #fff;
  border: 2px solid #fff;
}
.no-touch .button-outline-light:hover {
  background-color: #b3b3b3;
  border: 2px solid #b3b3b3;
  color: #313637;
}

.button-outline-dark {
  background-color: transparent;
  color: #313637;
  border: 2px solid #313637;
}
.no-touch .button-outline-dark:hover {
  background-color: #313637;
  border: 2px solid #313637;
  color: #fff;
}
.button-outline-dark.transparent {
  background-color: transparent;
  border: 1px solid rgba(255, 255, 255, 0.3);
  color: rgba(255, 255, 255, 0.3);
}
.no-touch .button-outline-dark.transparent:hover {
  background-color: transparent;
  color: #fff;
  border: 1px solid #fff;
}

/* ------------------------------------------------*/
/* Buttons & Triggers End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Forms and Forms Reply Groups Start */
/* ------------------------------------------------*/
.form-container {
  position: relative;
}

@media only screen and (min-width: 1200px) {
  .notify .form-container {
    max-width: 610px;
  }
}

.form {
  opacity: 1;
  -webkit-transition: opacity 0.5s ease-in-out;
  -o-transition: opacity 0.5s ease-in-out;
  -moz-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out;
}
.form.is-hidden {
  opacity: 0;
}

form {
  position: relative;
  width: 100%;
}
form input, form textarea {
  position: relative;
  display: block;
  width: 100%;
  border: none;
  outline: none;
  margin: 0;
  padding: 0;
  background-color: transparent;
  padding: 1.4rem 0.3rem;
  font: normal 500 1.6rem/1.7 "Montserrat", sans-serif;
  -webkit-transition: border-bottom 0.3s;
  -o-transition: border-bottom 0.3s;
  -moz-transition: border-bottom 0.3s;
  transition: border-bottom 0.3s;
}
form input {
  height: 4.4rem;
  margin: 0 0 2.4rem 0;
}
form input.margin-s {
  margin: 0 0 0.8rem 0;
}
@media only screen and (min-width: 1400px) {
  form input {
    height: 5rem;
  }
}
form textarea {
  height: 14rem;
  resize: none;
  margin: 0 0 0.8rem 0;
}
form .inputs-description {
  display: block;
  width: 100%;
  margin-bottom: 1.2rem;
  text-align: right;
  font: normal 400 1.2rem/1 "Montserrat", sans-serif;
}

.form-dark ::-webkit-input-placeholder {
  color: #838687;
}
.form-dark :-moz-placeholder {
  color: #838687;
}
.form-dark ::-moz-placeholder {
  color: #838687;
}
.form-dark :-ms-input-placeholder {
  color: #838687;
}
.form-dark input:focus:required:invalid,
.form-dark textarea:focus:required:invalid {
  color: #313637;
}
.form-dark input:required:valid,
.form-dark textarea:required:valid {
  color: #313637;
}
.form-dark input, .form-dark textarea {
  border-bottom: 1px solid #313637;
  color: #313637;
}
.form-dark input:focus, .form-dark textarea:focus {
  border-bottom: 1px solid #5a5e5f;
}
.form-dark .inputs-description {
  color: #5a5e5f;
}

.form-light ::-webkit-input-placeholder {
  color: #b3b3b3;
}
.form-light :-moz-placeholder {
  color: #b3b3b3;
}
.form-light ::-moz-placeholder {
  color: #b3b3b3;
}
.form-light :-ms-input-placeholder {
  color: #b3b3b3;
}
.form-light input:focus:required:invalid,
.form-light textarea:focus:required:invalid {
  color: #fff;
}
.form-light input:required:valid,
.form-light textarea:required:valid {
  color: #fff;
}
.form-light input, .form-light textarea {
  border-bottom: 1px solid #b3b3b3;
  color: #fff;
}
.form-light input:focus, .form-light textarea:focus {
  border-bottom: 1px solid #fff;
}
.form-light .inputs-description {
  color: #b3b3b3;
}

.reply-group {
  position: absolute;
  left: 50%;
  top: 50%;
  bottom: auto;
  right: auto;
  -webkit-transform: translateX(-50%) translateY(-50%);
     -moz-transform: translateX(-50%) translateY(-50%);
      -ms-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
  width: 100%;
  max-width: 300px;
  padding: 0 15px;
  text-align: center;
  opacity: 0;
  -webkit-transition: opacity 0.5s ease-in-out;
  -o-transition: opacity 0.5s ease-in-out;
  -moz-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out;
}
.reply-group.is-visible {
  opacity: 1;
}

.notify .reply-group {
  left: 0;
  top: 0;
  bottom: auto;
  right: auto;
  -webkit-transform: translateX(0) translateY(0);
     -moz-transform: translateX(0) translateY(0);
      -ms-transform: translateX(0) translateY(0);
          transform: translateX(0) translateY(0);
  text-align: left;
  max-width: none;
}

.reply-group__icon {
  display: block;
  margin: 0 auto 13px;
  font-size: 4rem;
  color: #838687;
}

.reply-group__title {
  font: normal 700 2rem/1.7 "Montserrat", sans-serif;
  color: #313637;
  margin-bottom: 7px;
}
.reply-group__title.light {
  color: #fff;
}

.reply-group__text {
  display: block;
  font: normal 400 1.4rem/1.7 "Montserrat", sans-serif;
  color: #313637;
}
.reply-group__text.light {
  color: #fff;
}
@media only screen and (min-width: 1400px) {
  .reply-group__text {
    font-size: 1.6rem;
  }
}

/* ------------------------------------------------*/
/* Forms and Forms Reply Groups End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Main Section Styles Start */
/* ------------------------------------------------*/
.section-main {
  position: relative;
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  background-color: #6f7273;
}
@media only screen and (min-width: 1200px) {
  .section-main {
    overflow: hidden;
  }
}

.section-main__intro {
  position: relative;
  width: 100%;
  background-color: #313637;
  z-index: 3;
  -webkit-transform: translateZ(0);
     -moz-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-transform: scale(1);
     -moz-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
  -webkit-transition: -webkit-transform 0.3s ease-in-out;
  transition: -webkit-transform 0.3s ease-in-out;
  -o-transition: transform 0.3s ease-in-out;
  -moz-transition: transform 0.3s ease-in-out, -moz-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out, -moz-transform 0.3s ease-in-out;
}
@media only screen and (min-width: 768px) {
  .section-main__intro {
    padding-bottom: 78px;
  }
}
@media only screen and (min-width: 1200px) {
  .section-main__intro {
    width: 75%;
    height: 100%;
    min-height: 568px;
    padding-bottom: 0;
  }
}
.section-main__intro.is-scaled-down {
  -webkit-transform: scale(1);
     -moz-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
}
@media only screen and (min-width: 1200px) {
  .section-main__intro.is-scaled-down {
    -webkit-transform: scale(0.92);
       -moz-transform: scale(0.92);
        -ms-transform: scale(0.92);
            transform: scale(0.92);
  }
}

.section-main__aside {
  position: relative;
  width: 100%;
  background-color: #fff;
  padding: 3rem 0;
}
@media only screen and (min-width: 1200px) {
  .section-main__aside {
    position: fixed;
    top: 0;
    right: 0;
    width: 25%;
    height: 100%;
    min-height: 568px;
    z-index: 10;
  }
}
@media only screen and (min-width: 1400px) {
  .section-main__aside {
    padding: 4rem 0;
  }
}

.intro__media {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.media__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center;
  -moz-background-size: cover;
       background-size: cover;
}

.intro__header {
  position: relative;
  margin-top: 3rem;
  padding: 0 3rem;
}
.intro__header .logo img {
  width: 140px;
}
@media only screen and (min-width: 768px) {
  .intro__header {
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .intro__header {
    margin-top: 4rem;
    padding: 0 6rem;
  }
}

.intro__headline {
  position: relative;
  padding: 12rem 3rem;
}
@media only screen and (min-width: 768px) {
  .intro__headline {
    padding: 12rem 5rem;
  }
}
@media only screen and (min-width: 1200px) {
  .intro__headline {
    position: absolute;
    left: 0;
    top: 50%;
    bottom: auto;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 100%;
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .intro__headline {
    padding: 0 6rem;
  }
}

.intro__countdown {
  position: relative;
  width: 100%;
  padding: 0 3rem 3rem 3rem;
}
@media only screen and (min-width: 768px) {
  .intro__countdown {
    position: absolute;
    bottom: 3rem;
    left: 0;
    width: auto;
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1200px) {
  .intro__countdown {
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .intro__countdown {
    bottom: 4rem;
    padding: 0 6rem;
  }
}

.intro__copyright {
  display: none;
  position: relative;
  width: 100%;
  padding: 0 3rem;
}
@media only screen and (min-width: 768px) {
  .intro__copyright {
    display: block;
    position: absolute;
    right: 0;
    bottom: 3rem;
    width: auto;
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1200px) {
  .intro__copyright {
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .intro__copyright {
    bottom: 4rem;
    padding: 0 6rem;
  }
}

.aside__content {
  position: relative;
  width: 100%;
  padding: 3rem;
  -webkit-transition: opacity 0.5s ease-in-out;
  -o-transition: opacity 0.5s ease-in-out;
  -moz-transition: opacity 0.5s ease-in-out;
  transition: opacity 0.5s ease-in-out;
}
.aside__content.animate-out {
  opacity: 1;
}
@media only screen and (min-width: 768px) {
  .aside__content {
    padding: 3rem 5rem;
  }
}
@media only screen and (min-width: 1200px) {
  .aside__content {
    position: absolute;
    left: 0;
    top: 50%;
    bottom: auto;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    padding: 0 5rem;
  }
  .aside__content.animate-out {
    opacity: 0;
    -webkit-transition: opacity 0.5s ease-in-out;
    -o-transition: opacity 0.5s ease-in-out;
    -moz-transition: opacity 0.5s ease-in-out;
    transition: opacity 0.5s ease-in-out;
  }
}
@media only screen and (min-width: 1400px) {
  .aside__content {
    padding: 0 6rem;
  }
}

.aside__socials {
  position: relative;
  width: 100%;
  padding: 3rem;
}
@media only screen and (min-width: 768px) {
  .aside__socials {
    padding: 3rem 5rem;
  }
}
@media only screen and (min-width: 1200px) {
  .aside__socials {
    position: absolute;
    right: 0;
    bottom: 3rem;
    width: auto;
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .aside__socials {
    bottom: 4rem;
    padding: 0 6rem;
  }
}

/* ------------------------------------------------*/
/* Main Section Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Menu Styles Start */
/* ------------------------------------------------*/
.menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  min-width: 320px;
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  z-index: 11;
  background-color: #313637;
  -webkit-transform: translateX(100%);
     -moz-transform: translateX(100%);
      -ms-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  -o-transition: transform 0.3s;
  -moz-transition: transform 0.3s, -moz-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
.menu .transition-el {
  opacity: 0;
  -webkit-transform: translateY(50px);
     -moz-transform: translateY(50px);
      -ms-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
  transition: opacity 0.3s, -webkit-transform 0.3s;
  -o-transition: opacity 0.3s, transform 0.3s;
  -moz-transition: opacity 0.3s, transform 0.3s, -moz-transform 0.3s;
  transition: opacity 0.3s, transform 0.3s;
  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
@media only screen and (min-width: 1200px) {
  .menu {
    position: absolute;
    top: 0;
    right: 0;
    left: auto;
    width: auto;
    min-width: auto;
    height: auto;
    overflow-y: hidden;
    -webkit-transform: translateX(0);
       -moz-transform: translateX(0);
        -ms-transform: translateX(0);
            transform: translateX(0);
    background-color: transparent;
    z-index: 4;
  }
  .menu .transition-el {
    opacity: 1;
    -webkit-transform: translateY(0);
       -moz-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
  }
}
.menu.is-visible {
  -webkit-transform: translateX(0);
     -moz-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
}
.menu.is-visible .transition-el {
  opacity: 1;
  -webkit-transform: translateY(0);
     -moz-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}
.menu.is-visible .transition-el-1 {
  -webkit-transition: opacity 0.3s 0.6s, color 0.3s, -webkit-transform 0.3s 0.6s;
  transition: opacity 0.3s 0.6s, color 0.3s, -webkit-transform 0.3s 0.6s;
  -o-transition: transform 0.3s 0.6s, opacity 0.3s 0.6s, color 0.3s;
  -moz-transition: transform 0.3s 0.6s, opacity 0.3s 0.6s, color 0.3s, -moz-transform 0.3s 0.6s;
  transition: transform 0.3s 0.6s, opacity 0.3s 0.6s, color 0.3s;
  transition: transform 0.3s 0.6s, opacity 0.3s 0.6s, color 0.3s, -webkit-transform 0.3s 0.6s, -moz-transform 0.3s 0.6s;
}
.menu.is-visible .transition-el-2 {
  -webkit-transition: opacity 0.3s 0.7s, color 0.3s, -webkit-transform 0.3s 0.7s;
  transition: opacity 0.3s 0.7s, color 0.3s, -webkit-transform 0.3s 0.7s;
  -o-transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, color 0.3s;
  -moz-transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, color 0.3s, -moz-transform 0.3s 0.7s;
  transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, color 0.3s;
  transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, color 0.3s, -webkit-transform 0.3s 0.7s, -moz-transform 0.3s 0.7s;
}
.menu.is-visible .transition-el-3 {
  -webkit-transition: opacity 0.3s 0.8s, color 0.3s, -webkit-transform 0.3s 0.8s;
  transition: opacity 0.3s 0.8s, color 0.3s, -webkit-transform 0.3s 0.8s;
  -o-transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, color 0.3s;
  -moz-transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, color 0.3s, -moz-transform 0.3s 0.8s;
  transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, color 0.3s;
  transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, color 0.3s, -webkit-transform 0.3s 0.8s, -moz-transform 0.3s 0.8s;
}
.menu.is-visible .transition-el-4 {
  -webkit-transition: opacity 0.3s 0.9s, color 0.3s, -webkit-transform 0.3s 0.9s;
  transition: opacity 0.3s 0.9s, color 0.3s, -webkit-transform 0.3s 0.9s;
  -o-transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, color 0.3s;
  -moz-transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, color 0.3s, -moz-transform 0.3s 0.9s;
  transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, color 0.3s;
  transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, color 0.3s, -webkit-transform 0.3s 0.9s, -moz-transform 0.3s 0.9s;
}

.menu__controls {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding: 3rem 3rem 0 3rem;
  z-index: 2;
  text-align: right;
}
@media only screen and (min-width: 1200px) {
  .menu__controls {
    display: none;
  }
}

.menu__container {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 480px;
  z-index: 1;
}
@media only screen and (min-width: 1200px) {
  .menu__container {
    height: auto;
    margin-top: 3rem;
  }
}
@media only screen and (min-width: 1400px) {
  .menu__container {
    margin-top: 4rem;
  }
}

.navigation {
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  bottom: auto;
  -webkit-transform: translateY(-50%);
     -moz-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 100%;
  padding: 0 3rem;
}
.navigation li {
  display: block;
  position: relative;
}
.navigation li a {
  display: block;
  padding: 1rem 0;
  font: normal 700 3.4rem/1 "Montserrat", sans-serif;
  color: #b3b3b3;
  -webkit-transition: color 0.3s ease-in-out;
  -o-transition: color 0.3s ease-in-out;
  -moz-transition: color 0.3s ease-in-out;
  transition: color 0.3s ease-in-out;
}
.no-touch .navigation li:hover a {
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .navigation {
    padding: 0 5rem;
  }
  .navigation li a {
    font-size: 6rem;
  }
}
@media only screen and (min-width: 1200px) {
  .navigation {
    position: relative;
    left: auto;
    top: auto;
    bottom: auto;
    -webkit-transform: translateY(0);
       -moz-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
    padding: 0 5rem;
  }
  .navigation li {
    display: inline-block;
  }
  .navigation li a {
    padding: 0;
    font: normal 700 1.6rem/1.2 "Montserrat", sans-serif;
    text-transform: none;
    margin-right: 3.6rem;
  }
  .navigation li:first-of-type {
    display: none;
  }
  .navigation li:last-of-type a {
    margin-right: 0;
  }
}
@media only screen and (min-width: 1400px) {
  .navigation {
    padding: 0 6rem;
  }
  .navigation li a {
    font-size: 1.8rem;
  }
}

/* ------------------------------------------------*/
/* Menu Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Socials Start */
/* ------------------------------------------------*/
.socials {
  display: block;
  position: relative;
  line-height: 1;
}
.socials li {
  display: inline-block;
}
.socials li a {
  display: block;
  font-size: 1.6rem;
  line-height: 1;
  color: #fff;
  margin-right: 2.7rem;
  -webkit-transition: color 0.3s ease-in-out;
  -o-transition: color 0.3s ease-in-out;
  -moz-transition: color 0.3s ease-in-out;
  transition: color 0.3s ease-in-out;
}
.no-touch .socials li a:hover {
  color: #b3b3b3;
}
.socials li:last-of-type a {
  margin-right: 0;
}

/* ------------------------------------------------*/
/* Socials End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Countdown Styles Start */
/* ------------------------------------------------*/
.countdown {
  position: relative;
}
.countdown::after {
  clear: both;
  content: "";
  display: table;
}
.countdown #countdown, .countdown .help-text {
  float: left;
}
.countdown #countdown {
  position: relative;
  font: normal 700 4.6rem/0.8 "Montserrat", sans-serif;
  color: #fff;
}
.countdown .help-text {
  font: normal 400 1.4rem/1.2 "Montserrat", sans-serif;
  color: #fff;
  padding-top: 0.5rem;
  margin-left: 1rem;
}
.countdown .countdown-period {
  display: none;
}
@media only screen and (min-width: 768px) {
  .countdown #countdown {
    font-size: 6rem;
  }
  .countdown .help-text {
    font-size: 1.6rem;
    padding-top: 1rem;
  }
}

/* ------------------------------------------------*/
/* Countdown Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Popup Dialogs Start */
/* ------------------------------------------------*/
.notify {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  overflow-y: auto;
  z-index: 4;
  background-color: #1d2021;
  -webkit-transform: translateX(101%);
     -moz-transform: translateX(101%);
      -ms-transform: translateX(101%);
          transform: translateX(101%);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  -o-transition: transform 0.3s;
  -moz-transition: transform 0.3s, -moz-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
.notify .transition-el {
  opacity: 0;
  -webkit-transform: translateY(50px);
     -moz-transform: translateY(50px);
      -ms-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
  transition: opacity 0.3s, -webkit-transform 0.3s;
  -o-transition: opacity 0.3s, transform 0.3s;
  -moz-transition: opacity 0.3s, transform 0.3s, -moz-transform 0.3s;
  transition: opacity 0.3s, transform 0.3s;
  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
@media only screen and (min-width: 1200px) {
  .notify {
    position: absolute;
    top: 0;
    right: auto;
    left: 0;
    width: 75%;
    min-height: 568px;
  }
}
.notify.is-visible {
  -webkit-transform: translateX(0);
     -moz-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
}
.notify.is-visible .transition-el {
  opacity: 1;
  -webkit-transform: translateY(0);
     -moz-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}
.notify.is-visible .transition-el-1 {
  -webkit-transition: opacity 0.3s 0.6s, -webkit-transform 0.3s 0.6s;
  transition: opacity 0.3s 0.6s, -webkit-transform 0.3s 0.6s;
  -o-transition: transform 0.3s 0.6s, opacity 0.3s 0.6s;
  -moz-transition: transform 0.3s 0.6s, opacity 0.3s 0.6s, -moz-transform 0.3s 0.6s;
  transition: transform 0.3s 0.6s, opacity 0.3s 0.6s;
  transition: transform 0.3s 0.6s, opacity 0.3s 0.6s, -webkit-transform 0.3s 0.6s, -moz-transform 0.3s 0.6s;
}
.notify.is-visible .transition-el-2 {
  -webkit-transition: opacity 0.3s 0.7s, -webkit-transform 0.3s 0.7s;
  transition: opacity 0.3s 0.7s, -webkit-transform 0.3s 0.7s;
  -o-transition: transform 0.3s 0.7s, opacity 0.3s 0.7s;
  -moz-transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, -moz-transform 0.3s 0.7s;
  transition: transform 0.3s 0.7s, opacity 0.3s 0.7s;
  transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, -webkit-transform 0.3s 0.7s, -moz-transform 0.3s 0.7s;
}
.notify.is-visible .transition-el-3 {
  -webkit-transition: opacity 0.3s 0.8s, border 0.5s, -webkit-transform 0.3s 0.8s;
  transition: opacity 0.3s 0.8s, border 0.5s, -webkit-transform 0.3s 0.8s;
  -o-transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, border 0.5s;
  -moz-transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, border 0.5s, -moz-transform 0.3s 0.8s;
  transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, border 0.5s;
  transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, border 0.5s, -webkit-transform 0.3s 0.8s, -moz-transform 0.3s 0.8s;
}
.notify.is-visible .transition-el-4 {
  -webkit-transition: opacity 0.3s 0.9s, background-color 0.3s, border 0.3s, color 0.3s, -webkit-transform 0.3s 0.9s;
  transition: opacity 0.3s 0.9s, background-color 0.3s, border 0.3s, color 0.3s, -webkit-transform 0.3s 0.9s;
  -o-transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, background-color 0.3s, border 0.3s, color 0.3s;
  -moz-transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, background-color 0.3s, border 0.3s, color 0.3s, -moz-transform 0.3s 0.9s;
  transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, background-color 0.3s, border 0.3s, color 0.3s;
  transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, background-color 0.3s, border 0.3s, color 0.3s, -webkit-transform 0.3s 0.9s, -moz-transform 0.3s 0.9s;
}

.notify__controls {
  position: relative;
  margin-top: 3rem;
  padding: 0 3rem;
}
@media only screen and (min-width: 768px) {
  .notify__controls {
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .notify__controls {
    margin-top: 4rem;
    padding: 0 6rem;
  }
}

.notify__content {
  position: relative;
  padding: 6rem 0;
  max-width: 700px;
}
.notify__content .content-block {
  position: relative;
  padding: 0 3rem;
  margin-bottom: 6rem;
}
.notify__content .content-block:last-of-type {
  margin-bottom: 0;
}
.notify__content .content-block.margin-bottom-s {
  margin-bottom: 3.8rem;
}
.notify__content .content-block.grid-block {
  padding: 0 -moz-calc(3rem - 15px);
  padding: 0 calc(3rem - 15px);
}
@media only screen and (min-width: 768px) {
  .notify__content .content-block {
    padding: 0 5rem;
  }
  .notify__content .content-block.grid-block {
    padding: 0 -moz-calc(5rem - 15px);
    padding: 0 calc(5rem - 15px);
  }
}
@media only screen and (min-width: 1200px) {
  .notify__content {
    position: absolute;
    left: 0;
    top: 50%;
    bottom: auto;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
@media only screen and (min-width: 1400px) {
  .notify__content {
    padding: 6rem 0;
  }
  .notify__content.no-padding-bottom {
    padding: 6rem 0 0 0;
  }
  .notify__content .content-block {
    padding: 0 6rem;
    margin-bottom: 7rem;
  }
  .notify__content .content-block.margin-bottom-s {
    margin-bottom: 4.8rem;
  }
  .notify__content .content-block.grid-block {
    padding: 0 -moz-calc(6rem - 15px);
    padding: 0 calc(6rem - 15px);
  }
}

.stayintouch {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow-y: auto;
  z-index: 11;
  background-color: #313637;
  opacity: 1;
  -webkit-transform: translateZ(0);
     -moz-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-transform: translateX(100%) translateY(0);
     -moz-transform: translateX(100%) translateY(0);
      -ms-transform: translateX(100%) translateY(0);
          transform: translateX(100%) translateY(0);
  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
  transition: opacity 0.3s, -webkit-transform 0.3s;
  -o-transition: opacity 0.3s, transform 0.3s;
  -moz-transition: opacity 0.3s, transform 0.3s, -moz-transform 0.3s;
  transition: opacity 0.3s, transform 0.3s;
  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
.stayintouch .transition-el {
  opacity: 0;
  -webkit-transform: translateY(50px);
     -moz-transform: translateY(50px);
      -ms-transform: translateY(50px);
          transform: translateY(50px);
  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
  transition: opacity 0.3s, -webkit-transform 0.3s;
  -o-transition: opacity 0.3s, transform 0.3s;
  -moz-transition: opacity 0.3s, transform 0.3s, -moz-transform 0.3s;
  transition: opacity 0.3s, transform 0.3s;
  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
}
.stayintouch .opacity-el {
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  -o-transition: opacity 0.3s;
  -moz-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.stayintouch.animate-in {
  -webkit-transform: translateX(0) translateY(0);
     -moz-transform: translateX(0) translateY(0);
      -ms-transform: translateX(0) translateY(0);
          transform: translateX(0) translateY(0);
}
.stayintouch.animate-in .transition-el {
  opacity: 1;
  -webkit-transform: translateY(0);
     -moz-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}
.stayintouch.animate-in .opacity-el {
  opacity: 1;
}
.stayintouch.animate-in .transition-el-1 {
  -webkit-transition: opacity 0.3s 0.6s, -webkit-transform 0.3s 0.6s;
  transition: opacity 0.3s 0.6s, -webkit-transform 0.3s 0.6s;
  -o-transition: transform 0.3s 0.6s, opacity 0.3s 0.6s;
  -moz-transition: transform 0.3s 0.6s, opacity 0.3s 0.6s, -moz-transform 0.3s 0.6s;
  transition: transform 0.3s 0.6s, opacity 0.3s 0.6s;
  transition: transform 0.3s 0.6s, opacity 0.3s 0.6s, -webkit-transform 0.3s 0.6s, -moz-transform 0.3s 0.6s;
}
.stayintouch.animate-in .transition-el-2 {
  -webkit-transition: opacity 0.3s 0.7s, border 0.3s, -webkit-transform 0.3s 0.7s;
  transition: opacity 0.3s 0.7s, border 0.3s, -webkit-transform 0.3s 0.7s;
  -o-transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, border 0.3s;
  -moz-transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, border 0.3s, -moz-transform 0.3s 0.7s;
  transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, border 0.3s;
  transition: transform 0.3s 0.7s, opacity 0.3s 0.7s, border 0.3s, -webkit-transform 0.3s 0.7s, -moz-transform 0.3s 0.7s;
}
.stayintouch.animate-in .transition-el-3 {
  -webkit-transition: opacity 0.3s 0.8s, border 0.3s, -webkit-transform 0.3s 0.8s;
  transition: opacity 0.3s 0.8s, border 0.3s, -webkit-transform 0.3s 0.8s;
  -o-transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, border 0.3s;
  -moz-transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, border 0.3s, -moz-transform 0.3s 0.8s;
  transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, border 0.3s;
  transition: transform 0.3s 0.8s, opacity 0.3s 0.8s, border 0.3s, -webkit-transform 0.3s 0.8s, -moz-transform 0.3s 0.8s;
}
.stayintouch.animate-in .transition-el-4 {
  -webkit-transition: opacity 0.3s 0.9s, border 0.3s, -webkit-transform 0.3s 0.9s;
  transition: opacity 0.3s 0.9s, border 0.3s, -webkit-transform 0.3s 0.9s;
  -o-transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, border 0.3s;
  -moz-transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, border 0.3s, -moz-transform 0.3s 0.9s;
  transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, border 0.3s;
  transition: transform 0.3s 0.9s, opacity 0.3s 0.9s, border 0.3s, -webkit-transform 0.3s 0.9s, -moz-transform 0.3s 0.9s;
}
.stayintouch.animate-in .transition-el-5 {
  -webkit-transition: opacity 0.3s 1s, background-color 0.3s, -webkit-transform 0.3s 1s;
  transition: opacity 0.3s 1s, background-color 0.3s, -webkit-transform 0.3s 1s;
  -o-transition: transform 0.3s 1s, opacity 0.3s 1s, background-color 0.3s;
  -moz-transition: transform 0.3s 1s, opacity 0.3s 1s, background-color 0.3s, -moz-transform 0.3s 1s;
  transition: transform 0.3s 1s, opacity 0.3s 1s, background-color 0.3s;
  transition: transform 0.3s 1s, opacity 0.3s 1s, background-color 0.3s, -webkit-transform 0.3s 1s, -moz-transform 0.3s 1s;
}
.stayintouch.animate-in .opacity-el-1 {
  -webkit-transition: opacity 0.3s 1.2s;
  -o-transition: opacity 0.3s 1.2s;
  -moz-transition: opacity 0.3s 1.2s;
  transition: opacity 0.3s 1.2s;
}
.stayintouch.animate-out {
  opacity: 1;
}
@media only screen and (min-width: 1200px) {
  .stayintouch {
    position: absolute;
    top: 0;
    right: 0;
    background-color: transparent;
    -webkit-transform: translateX(0) translateY(100%);
       -moz-transform: translateX(0) translateY(100%);
        -ms-transform: translateX(0) translateY(100%);
            transform: translateX(0) translateY(100%);
  }
  .stayintouch.animate-in {
    -webkit-transform: translateX(0) translateY(0);
       -moz-transform: translateX(0) translateY(0);
        -ms-transform: translateX(0) translateY(0);
            transform: translateX(0) translateY(0);
  }
  .stayintouch.animate-out {
    opacity: 0;
  }
}

.stayintouch__controls {
  position: relative;
  margin-top: 3rem;
  padding: 0 3rem;
}
@media only screen and (min-width: 768px) {
  .stayintouch__controls {
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .stayintouch__controls {
    margin-top: 4rem;
    padding: 0 6rem;
  }
}

.stayintouch__content {
  position: relative;
  padding: 6rem 0;
  max-width: 700px;
}
.stayintouch__content .content-block {
  position: relative;
  padding: 0 3rem;
  margin-bottom: 6rem;
}
.stayintouch__content .content-block:last-of-type {
  margin-bottom: 0;
}
.stayintouch__content .content-block.margin-bottom-s {
  margin-bottom: 3.8rem;
}
.stayintouch__content .content-block.grid-block {
  padding: 0 -moz-calc(3rem - 15px);
  padding: 0 calc(3rem - 15px);
}
@media only screen and (min-width: 768px) {
  .stayintouch__content .content-block {
    padding: 0 5rem;
  }
  .stayintouch__content .content-block.grid-block {
    padding: 0 -moz-calc(5rem - 15px);
    padding: 0 calc(5rem - 15px);
  }
}
@media only screen and (min-width: 1200px) {
  .stayintouch__content {
    max-width: none;
  }
}
@media only screen and (min-width: 1400px) {
  .stayintouch__content {
    padding: 7rem 0;
  }
  .stayintouch__content.no-padding-bottom {
    padding: 7rem 0 0 0;
  }
  .stayintouch__content .content-block {
    padding: 0 6rem;
    margin-bottom: 7rem;
  }
  .stayintouch__content .content-block.margin-bottom-s {
    margin-bottom: 4.8rem;
  }
  .stayintouch__content .content-block.grid-block {
    padding: 0 -moz-calc(6rem - 15px);
    padding: 0 calc(6rem - 15px);
  }
}

/* ------------------------------------------------*/
/* Popup Dialogs End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Content Section Styles Start */
/* ------------------------------------------------*/
.section-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow-y: auto;
  background-color: #fff;
  opacity: 1;
  -webkit-transform: translateX(101%);
     -moz-transform: translateX(101%);
      -ms-transform: translateX(101%);
          transform: translateX(101%);
  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
  transition: opacity 0.3s, -webkit-transform 0.3s;
  -o-transition: opacity 0.3s, transform 0.3s;
  -moz-transition: opacity 0.3s, transform 0.3s, -moz-transform 0.3s;
  transition: opacity 0.3s, transform 0.3s;
  transition: opacity 0.3s, transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
  z-index: 8;
}
.section-inner::after {
  display: none;
  content: "";
}
.section-inner.is-visible {
  -webkit-transform: translateX(0);
     -moz-transform: translateX(0);
      -ms-transform: translateX(0);
          transform: translateX(0);
}
@media only screen and (min-width: 1200px) {
  .section-inner {
    width: 75%;
  }
  .section-inner::after {
    content: "custom-scrollbar";
  }
}

.section-inner__controls {
  position: relative;
  margin-top: 3rem;
  padding: 0 3rem;
}
@media only screen and (min-width: 768px) {
  .section-inner__controls {
    padding: 0 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .section-inner__controls {
    margin-top: 4rem;
    padding: 0 6rem;
  }
}

.section-inner__blocks {
  position: relative;
  padding: 6rem 0;
}
.section-inner__blocks.no-padding-bottom {
  padding: 6rem 0 0 0;
}
.section-inner__blocks .content-block {
  position: relative;
  padding: 0 3rem;
  margin-bottom: 6rem;
}
.section-inner__blocks .content-block:last-of-type {
  margin-bottom: 0;
}
.section-inner__blocks .content-block.grid-block {
  padding: 0 -moz-calc(3rem - 15px);
  padding: 0 calc(3rem - 15px);
}
.section-inner__blocks .content-block.margin-bottom-s {
  margin-bottom: 3.6rem;
}
.section-inner__blocks .content-block.features, .section-inner__blocks .content-block.blockquote, .section-inner__blocks .content-block.map {
  padding: 0;
  margin-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .section-inner__blocks .content-block {
    padding: 0 5rem;
  }
  .section-inner__blocks .content-block.grid-block {
    padding: 0 -moz-calc(5rem - 15px);
    padding: 0 calc(5rem - 15px);
  }
}
@media only screen and (min-width: 1400px) {
  .section-inner__blocks {
    padding: 7rem 0;
  }
  .section-inner__blocks.no-padding-bottom {
    padding: 7rem 0 0 0;
  }
  .section-inner__blocks .content-block {
    padding: 0 6rem;
    margin-bottom: 7rem;
  }
  .section-inner__blocks .content-block.grid-block {
    padding: 0 -moz-calc(6rem - 15px);
    padding: 0 calc(6rem - 15px);
  }
  .section-inner__blocks .content-block.margin-bottom-s {
    margin-bottom: 4.4rem;
  }
}

.blockquote__container {
  position: relative;
  padding: 6rem 3rem;
  background-repeat: no-repeat;
  background-position: bottom center;
  -moz-background-size: cover;
       background-size: cover;
}
@media only screen and (min-width: 768px) {
  .blockquote__container {
    padding: 8rem 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .blockquote__container {
    padding: 12rem 6rem;
  }
}

/* ------------------------------------------------*/
/* Content Section Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Features Start */
/* ------------------------------------------------*/
.feature__image {
  position: relative;
  width: 100%;
  height: 320px;
  background-color: #313637;
  background-repeat: no-repeat;
  -moz-background-size: cover;
       background-size: cover;
}
@media only screen and (min-width: 768px) {
  .feature__image {
    height: 100%;
  }
}

.feature__descr {
  position: relative;
  padding: 6rem 3rem;
  text-align: center;
}
.feature__descr img {
  width: auto;
  margin: 0 auto 2.8rem;
}
@media only screen and (min-width: 768px) {
  .feature__descr {
    padding: 8rem 5rem;
  }
}
@media only screen and (min-width: 1400px) {
  .feature__descr {
    padding: 12rem 6rem;
  }
  .feature__descr p {
    max-width: 400px;
    margin: 0 auto;
  }
}

/* ------------------------------------------------*/
/* Features End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Google Map Start */
/* ------------------------------------------------*/
#google-container {
  position: relative;
  width: 100%;
  height: 100vh;
}

#google-map {
  position: relative;
  height: 100%;
}
@media only screen and (min-width: 1200px) {
  #google-map {
    width: 100%;
  }
}

#zoom-in, #zoom-out {
  position: relative;
  height: 40px;
  width: 40px;
  cursor: pointer;
  margin-right: 1rem;
  background-color: #313637;
  color: #fff;
  -moz-border-radius: 4px;
       border-radius: 4px;
  -webkit-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  -moz-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.no-touch #zoom-in:hover, .no-touch #zoom-out:hover {
  background-color: #6f7273;
}
#zoom-in i, #zoom-out i {
  font-size: 1.4rem;
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  bottom: auto;
  right: auto;
  -webkit-transform: translateX(-50%) translateY(-50%);
     -moz-transform: translateX(-50%) translateY(-50%);
      -ms-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
}

#zoom-out {
  margin-top: 0.6rem;
  margin-bottom: 1rem;
}

/* ------------------------------------------------*/
/* Google Map End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Gallery Custom Styles Start */
/* ------------------------------------------------*/
.my-gallery__item {
  display: block;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  margin-bottom: 30px;
}
.my-gallery__item:last-of-type {
  margin-bottom: 0;
}
@media only screen and (min-width: 576px) {
  .my-gallery__item:nth-of-type(5) {
    margin-bottom: 0;
  }
}
@media only screen and (min-width: 1200px) {
  .my-gallery__item img {
    opacity: 1;
    -webkit-transition: opacity 0.6s;
    -o-transition: opacity 0.6s;
    -moz-transition: opacity 0.6s;
    transition: opacity 0.6s;
  }
  .no-touch .my-gallery__item:hover img {
    opacity: 0.5;
  }
  .no-touch .my-gallery__item:hover .my-gallery__descr::after {
    -webkit-transform: translateX(0);
       -moz-transform: translateX(0);
        -ms-transform: translateX(0);
            transform: translateX(0);
  }
  .no-touch .my-gallery__item:hover .my-gallery__descr h4 {
    opacity: 1;
  }
}

.my-gallery__descr {
  position: absolute;
  left: 30px;
  bottom: 15px;
  width: auto;
  max-width: -moz-calc(100% - 60px);
  max-width: calc(100% - 60px);
  height: auto;
  padding: 1.4rem 2.4rem;
  color: #fff;
  z-index: 1;
  overflow: hidden;
}
.my-gallery__descr::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #313637;
  z-index: -1;
}
.my-gallery__descr h4 {
  display: block;
  z-index: 2;
}
.my-gallery__descr p {
  display: none;
}
@media only screen and (min-width: 1200px) {
  .my-gallery__descr::after {
    -webkit-transform: translateX(-102%);
       -moz-transform: translateX(-102%);
        -ms-transform: translateX(-102%);
            transform: translateX(-102%);
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    -o-transition: transform 0.3s;
    -moz-transition: transform 0.3s, -moz-transform 0.3s;
    transition: transform 0.3s;
    transition: transform 0.3s, -webkit-transform 0.3s, -moz-transform 0.3s;
  }
  .my-gallery__descr h4 {
    opacity: 0;
    -webkit-transition: opacity 0.3s 0.1s;
    -o-transition: opacity 0.3s 0.1s;
    -moz-transition: opacity 0.3s 0.1s;
    transition: opacity 0.3s 0.1s;
  }
}

.pswp__caption__center h4 {
  font: normal 700 1.5rem/1.2 "Montserrat", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: #fff;
}
.pswp__caption__center h4 small {
  display: block;
  margin-top: 0.2rem;
  font: italic 400 1.3rem/1.2 "Montserrat", sans-serif;
  text-transform: none;
  color: #fff;
}
.pswp__caption__center p {
  font: normal 400 1.4rem/1.7 "Montserrat", sans-serif;
  color: #fff;
  margin-top: 1.4rem;
}
@media only screen and (min-width: 1400px) {
  .pswp__caption__center h4 {
    font-size: 1.9rem;
  }
  .pswp__caption__center h4 small {
    font-size: 1.4rem;
  }
}

.pswp__counter {
  font: normal 500 1.4rem/44px "Montserrat", sans-serif;
  color: #fff;
}

.pswp__button--close {
  opacity: 1;
}

.pswp__button--arrow--left::before, .pswp__button--arrow--right::before {
  width: 44px;
  height: 44px;
}

.pswp__button--arrow--left:before {
  left: 0;
  background-position: -132px -44px;
}

.pswp__button--arrow--right:before {
  right: 0;
  background-position: -88px -44px;
}

.pswp__bg {
  background: #191b1c;
}

.pswp__caption, .pswp__top-bar {
  background-color: rgba(0, 0, 0, 0.3);
}

.pswp__button--close {
  position: relative;
  background-color: #fff;
}
.pswp__button--close:active {
  opacity: 1;
}

/* ------------------------------------------------*/
/* Scheduling */
/* ------------------------------------------------*/
.agenda-wrapper {
  max-width: 1600px;
  margin: 0 auto;
}

.agenda-header {
  margin-bottom: 20px;
}

.agenda-header h1 {
  font-size: 28px;
  margin-bottom: 5px;
}

.agenda-header p {
  color: #666;
  font-size: 14px;
}

.agenda-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}

.day-box {
  background: #fff;
  border-radius: 4px;
  border: 1px solid #e3e7ee;
  min-height: 150px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
  overflow: hidden;
}

.day-title {
  font-weight: bold;
  font-size: 14px;
  margin-bottom: 10px;
  border-bottom: 1px solid #eef2f7;
  padding-bottom: 8px;
}

.tags {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.tag {
  display: inline-block;
  padding: 4px 4px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  width: 100%;
  word-break: break-word;
}

.tag.color {
  background: #e3e3e3;
}

/* Tablet */
@media (max-width: 1100px) {
  .agenda-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Mobile */
@media (max-width: 700px) {
  .agenda-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .day-box {
    min-height: 140px;
  }
}

/* Mobile pequeno */
@media (max-width: 480px) {
  .agenda-grid {
    grid-template-columns: 1fr;
  }

  .agenda-header h1 {
    font-size: 22px;
  }
}

/* ------------------------------------------------*/
/* Weekly Planner */
/* ------------------------------------------------*/
.weekly-planner-wrap {
  max-width: 1100px;
  margin: 0 auto;
}

.weekly-planner-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.planner-day-card {
  background: #fff;
  border: 1px solid #e3e7ee;
  border-radius: 8px;
  padding: 14px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.planner-day-card-full {
  grid-column: 1 / -1;
}

.planner-day-head {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid #eef2f7;
}

.planner-period-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.planner-period-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.planner-period-label {
  font-size: 13px;
  font-weight: 600;
  color: #444;
  margin: 0;
}

.planner-period-input {
  width: 100%;
  height: 38px;
  border: 1px solid #d9dee7;
  border-radius: 6px;
  padding: 0 12px;
  font-size: 14px;
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.planner-period-input:focus {
  border-color: #ff1644;
  box-shadow: 0 0 0 3px rgba(255, 22, 68, 0.08);
}

/* Tablet e mobile */
@media (max-width: 768px) {
  .weekly-planner-grid {
    grid-template-columns: 1fr;
  }

  .planner-day-card-full {
    grid-column: auto;
  }
}

.form-check-input {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid #ccc;
  border-radius: 6px; 
  background-color: #fff;
  cursor: pointer;
  position: relative;
  transition: all 0.2s ease;
}
.form-check-input:hover {
  border-color: #ff1644;
}
.form-check-input:checked {
  background-color: #ff1644;
  border-color: #ff1644;
}
.form-check-input:checked::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 1px;
  width: 6px;
  height: 12px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.form-check-label {
  cursor: pointer;
  margin-left: 6px;
  font-size: 14px;
  user-select: none;
}
.form-check-input:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(255, 22, 68, 0.2);
}
.form-check {
  display: flex;
  align-items: center;
  padding-left:0px !important;
}
.form-check-input {
  margin: 0;
}


.color-select{
    position:relative;
}

.color-select-trigger{
    width:100%;
    height:40px;
    border:1px solid #d8d6de;
    background:#fff;
    border-radius:5px;
    padding:0 14px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    cursor:pointer;
    transition:all .18s ease;
    box-shadow:0 2px 10px rgba(0,0,0,0.04);
}

.color-select-trigger:hover{
    border-color:#bdbdbd;
    box-shadow:0 4px 14px rgba(0,0,0,0.07);
}

.color-select.open .color-select-trigger{
    box-shadow:0 0 0 4px rgba(0,0,0,0.05);
}

.color-select-current{
    display:flex;
    align-items:center;
    gap:10px;
    min-width:0;
}

.color-select-label{
    font-size:14px;
    font-weight:600;
    color:#222;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.color-select-arrow{
    font-size:12px;
    color:#666;
    transition:transform .18s ease;
}

.color-select.open .color-select-arrow{
    transform:rotate(180deg);
}

.color-dot{
    width:18px;
    height:18px;
    border-radius:4px;
    display:inline-block;
    border:1px solid rgba(0,0,0,0.08);
    flex:0 0 18px;
}

.color-border{
    border:1px solid #cfcfcf;
}

.color-other{
    background:
        linear-gradient(45deg, #fff 25%, #d9d9d9 25%, #d9d9d9 50%, #fff 50%, #fff 75%, #d9d9d9 75%, #d9d9d9 100%);
    background-size:8px 8px;
    border:1px solid #cfcfcf;
}

.color-select-dropdown{
    position:absolute;
    top:50px;
    left:0;
    width: 62px;
    background:#fff;
    border:1px solid #e3e3e3;
    border-radius:14px;
    padding:8px;
    box-shadow:0 16px 40px rgba(0,0,0,0.12);
    display:none;
    z-index:999;
    max-height:260px;
    overflow-y:auto;
}

.color-select.open .color-select-dropdown{
    display:block;
}

.color-option{
    display:flex;
    align-items:center;
    gap:10px;
    padding:10px 12px;
    border-radius:10px;
    cursor:pointer;
    transition:background .15s ease;
}

.color-option:hover{
    background:#f7f7f7;
}

.color-option-name{
    font-size:14px;
    color:#333;
    font-weight:500;
}

/* Blink Animation DIV */
.fade-loop {
    opacity: 1;
}
.fade-loop.animate {
    animation: opacityPulse 2s ease-out infinite;
}
@keyframes opacityPulse {
    0% {
        opacity: 0.1;
    }
    100% {
        opacity: 0.4;
    }
}
.fade-loop2 {
    opacity: 1;
}
.fade-loop2.animate {
    animation: opacityPulse2 2s ease-out infinite;
}
@keyframes opacityPulse2 {
    0% {
        opacity: 0.3;
    }
    100% {
        opacity: 1;
    }
}

.bold{
	font-weight:800;
}


.medias-header{
	display:flex;
	align-items:center;
	gap:6px;
	flex-wrap:wrap;
}

.medias-title{
	display:inline-flex;
	align-items:center;
}

.medias-actions{
	display:inline-flex;
	align-items:center;
	gap:6px;
	flex-wrap:wrap;
}

@media (max-width: 767px){
	.medias-title{
		width:100%;
	}
	.medias-actions{
		width:100%;
	}
}

html, body{
	-webkit-user-select:none;
	-moz-user-select:none;
	-ms-user-select:none;
	user-select:none;
}

input,
textarea,
[contenteditable="true"]{
	-webkit-user-select:text;
	-moz-user-select:text;
	-ms-user-select:text;
	user-select:text;
}


.media-dragging{
	opacity:.45;
}

.calendar-drop-hover{
	min-height:120px;
	background:rgba(0,0,0,.03);
	border-radius:12px;
}
.media-drop-placed{
	animation: mediaDropPlaced .2s ease-out;
}

.media-drop-placed .thumb_box{
	border:2px solid #ff1644;
	animation: mediaDropBorder .2s ease-out forwards;
}

@keyframes mediaDropPlaced{
	from{
		transform:scale(.9);
	}
	to{
		transform:scale(1);
	}
}

@keyframes mediaDropBorder{
	from{
		border-color:#ff1644;
	}
	to{
		border-color:transparent;
	}
}