/*! ------------------------------------------------
 * Project Name: Ramio - Clean Coming Soon and Landing Page Template
 * Project Description: Ramio - awesome coming soon template to kick-start your project
 * Tags: Ramio, coming soon, under construction, template, coming soon page, html5, css3
 * Version: 2.0.3
 * Build Date: April 2018
 * 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. Loading Animation
 *  5. Animated Backgrounds
 *  6. Typography
 *  7. Buttons & Triggers
 *  8. Forms and Form Reply Groups
 *  9. Main Section
 *  10. Menu
 *  11. Socials
 *  12. Countdown
 *  13. Content Sections
 *  14. Custom Scroll
 *  15. Section Title
 *  16. Features
 *  17. Blockquote
 *  18. Team
 *  19. Gallery
 *  20. Contact Data
 *  21. Google Map
 *  22. Popup Forms
 * ------------------------------------------------
 * Table of Contents End
 * ------------------------------------------------ */
/* ------------------------------------------------*/
/* Template Backgrounds Start */
/* ------------------------------------------------*/

.language-switcher {
    display: flex;
    gap: 1.3rem; /* Abstand zwischen den Sprachen */
    align-items: center;
}

.language-switcher a {
    color: white;
    text-decoration: none;
    font-weight: 500;
}

.language-switcher a.active {
    font-weight: 700;
    text-decoration: none;
    border-bottom: 2px solid #40e0d0;
    padding-bottom: 2px;
}

.language-switcher a:not(.active):hover {
    font-weight: 700;
    text-decoration: none;
    border-bottom: 2px solid #40e0d0;
    padding-bottom: 2px;
}

.media-1 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.media-2 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.media-3 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.media-4 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.media-5 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.media-6 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.media-7 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.media-8 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.media-9 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.media-10 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.static-bg-1 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.static-bg-2 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.static-bg-3 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.static-bg-4 {
    background-image: url("https://dummyimage.com/900x1200/575757/949494");
}

.static-bg-5 {
    background-image: url("/assets/img/backgrounds/about_us_cover.jpg");
}

.static-bg-6 {
    background-image: url("/assets/img/backgrounds/contact.jpg");
}

.static-bg-7 {
    background-image: url("/assets/img/backgrounds/list-it.jpg");
}

.feature-1 {
    background-image: url("https://dummyimage.com/1200x900/575757/949494");
}

.feature-2 {
    background-image: url("https://dummyimage.com/1200x900/575757/949494");
}

.feature-3 {
    background-image: url("https://dummyimage.com/1200x900/575757/949494");
}

.feature-4 {
    background-image: url("https://dummyimage.com/1200x900/575757/949494");
}

.feature-dark-1 {
    background-image: url("/assets/img/backgrounds/Verified-Local-Listings.jpg");
}

.feature-dark-2 {
    background-image: url("/assets/img/backgrounds/Direct-Booking.jpg");
}

.feature-dark-3 {
    background-image: url("/assets/img/backgrounds/Real-Reviews-Real-Guests.jpg");
}

.feature-dark-4 {
    background-image: url("/assets/img/backgrounds/local_guide.jpg");
}

.blockquote {
    background-image: url("https://dummyimage.com/1200x1080/cecece/949494");
}

.blockquote-dark {
    background-image: url("/assets/img/backgrounds/discover-macedonia.jpg");
}

/* ------------------------------------------------*/
/* Template Backgrounds End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Fonts Start */
/* ------------------------------------------------*/
/* Poppins Font */
@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 300;
    src: url("../fonts/Poppins-Light/Poppins-Light.eot?#iefix")
            format("embedded-opentype"),
        url("../fonts/Poppins-Light/Poppins-Light.woff") format("woff"),
        url("../fonts/Poppins-Light/Poppins-Light.ttf") format("truetype");
}
@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 400;
    src: url("../fonts/Poppins-Regular/Poppins-Regular.eot?#iefix")
            format("embedded-opentype"),
        url("../fonts/Poppins-Regular/Poppins-Regular.woff") format("woff"),
        url("../fonts/Poppins-Regular/Poppins-Regular.ttf") format("truetype");
}
@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 500;
    src: url("../fonts/Poppins-Medium/Poppins-Medium.eot?#iefix")
            format("embedded-opentype"),
        url("../fonts/Poppins-Medium/Poppins-Medium.woff") format("woff"),
        url("../fonts/Poppins-Medium/Poppins-Medium.ttf") format("truetype");
}
@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 700;
    src: url("../fonts/Poppins-Bold/Poppins-Bold.eot?#iefix")
            format("embedded-opentype"),
        url("../fonts/Poppins-Bold/Poppins-Bold.woff") format("woff"),
        url("../fonts/Poppins-Bold/Poppins-Bold.ttf") format("truetype");
}
@font-face {
    font-family: "Poppins";
    font-style: normal;
    font-weight: 800;
    src: url("../fonts/Poppins-ExtraBold/Poppins-ExtraBold.eot?#iefix")
            format("embedded-opentype"),
        url("../fonts/Poppins-ExtraBold/Poppins-ExtraBold.woff") format("woff"),
        url("../fonts/Poppins-ExtraBold/Poppins-ExtraBold.ttf")
            format("truetype");
}
/* Libre Baskerville Italic Font */
@font-face {
    font-family: "Libre Baskerville";
    font-style: normal;
    font-weight: 400;
    src: url("../fonts/LibreBaskerville-Italic/LibreBaskerville-Italic.eot?#iefix")
            format("embedded-opentype"),
        url("../fonts/LibreBaskerville-Italic/LibreBaskerville-Italic.woff")
            format("woff"),
        url("../fonts/LibreBaskerville-Italic/LibreBaskerville-Italic.ttf")
            format("truetype");
}
/* ------------------------------------------------*/
/* Fonts End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Base CSS Styles Start */
/* ------------------------------------------------*/
*,
*::before,
*::after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

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

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

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

*:focus {
    outline: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
}

*:active {
    outline: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
}

::-moz-focus-inner {
    border: 0;
}

::-moz-selection {
    background-color: #343434;
    color: #b6b6b6;
    text-shadow: none;
}

::selection {
    background-color: #343434;
    color: #b6b6b6;
    text-shadow: none;
}

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

@media only screen and (min-width: 1200px) {
    html,
    body {
        width: 100%;
        height: 100%;
    }
}

body {
    min-width: 320px;
    position: relative;
    overflow-x: hidden;
    font: normal 400 1.6rem/1.7 "Poppins", sans-serif;
    background-color: rgb(31.2, 31.2, 31.2);
    color: #616161;
}
@media only screen and (min-width: 1200px) {
    body {
        overflow: hidden;
    }
}

section {
    position: relative;
}

a {
    text-decoration: underline;
    color: #303030;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-tap-highlight-color: transparent;
    outline: none;
}

button:focus {
    outline: none !important;
    -webkit-box-shadow: none !important;
    -moz-box-shadow: none !important;
    box-shadow: none !important;
}

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

.no-padding {
    padding: 0;
}

.overflow-hidden {
    overflow: hidden;
}

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

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

/* ------------------------------------------------*/
/* Base CSS Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Loading Animation Start */
/* ------------------------------------------------*/
.intro__content {
    opacity: 0;
}

.media__image {
    opacity: 0;
}

@-webkit-keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@-moz-keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
@-webkit-keyframes fadeInLeft {
    from {
        opacity: 0;
        -webkit-transform: translate3d(-50px, 0, 0);
        transform: translate3d(-50px, 0, 0);
    }
    to {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}
@-moz-keyframes fadeInLeft {
    from {
        opacity: 0;
        -moz-transform: translate3d(-50px, 0, 0);
        transform: translate3d(-50px, 0, 0);
    }
    to {
        opacity: 1;
        -moz-transform: none;
        transform: none;
    }
}
@keyframes fadeInLeft {
    from {
        opacity: 0;
        -webkit-transform: translate3d(-50px, 0, 0);
        -moz-transform: translate3d(-50px, 0, 0);
        transform: translate3d(-50px, 0, 0);
    }
    to {
        opacity: 1;
        -webkit-transform: none;
        -moz-transform: none;
        transform: none;
    }
}
@-webkit-keyframes blockMove {
    0% {
        -webkit-transform: translateX(-102%);
        transform: translateX(-102%);
    }
    40% {
        -webkit-transform: translateX(0);
        transform: translateX(0);
    }
    50% {
        -webkit-transform: translateX(0);
        transform: translateX(0);
    }
    100% {
        -webkit-transform: translateX(102%);
        transform: translateX(102%);
    }
}
@-moz-keyframes blockMove {
    0% {
        -moz-transform: translateX(-102%);
        transform: translateX(-102%);
    }
    40% {
        -moz-transform: translateX(0);
        transform: translateX(0);
    }
    50% {
        -moz-transform: translateX(0);
        transform: translateX(0);
    }
    100% {
        -moz-transform: translateX(102%);
        transform: translateX(102%);
    }
}
@keyframes blockMove {
    0% {
        -webkit-transform: translateX(-102%);
        -moz-transform: translateX(-102%);
        transform: translateX(-102%);
    }
    40% {
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        transform: translateX(0);
    }
    50% {
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        transform: translateX(0);
    }
    100% {
        -webkit-transform: translateX(102%);
        -moz-transform: translateX(102%);
        transform: translateX(102%);
    }
}
@-webkit-keyframes itemsOpacity {
    0% {
        opacity: 0;
    }
    40% {
        opacity: 0;
    }
    60% {
        opacity: 1;
    }
    100% {
        opacity: 1;
    }
}
@-moz-keyframes itemsOpacity {
    0% {
        opacity: 0;
    }
    40% {
        opacity: 0;
    }
    60% {
        opacity: 1;
    }
    100% {
        opacity: 1;
    }
}
@keyframes itemsOpacity {
    0% {
        opacity: 0;
    }
    40% {
        opacity: 0;
    }
    60% {
        opacity: 1;
    }
    100% {
        opacity: 1;
    }
}
.main.loaded .main__intro .intro__content {
    -webkit-animation: 0.8s ease-in-out 1 both itemsOpacity;
    -moz-animation: 0.8s ease-in-out 1 both itemsOpacity;
    animation: 0.8s ease-in-out 1 both itemsOpacity;
}
.main.loaded .main__intro::before {
    -webkit-animation: 0.8s ease-in-out 1 both blockMove;
    -moz-animation: 0.8s ease-in-out 1 both blockMove;
    animation: 0.8s ease-in-out 1 both blockMove;
}
.main.loaded .main__media .media__image {
    -webkit-animation: 0.8s ease-in-out 1 both itemsOpacity;
    -moz-animation: 0.8s ease-in-out 1 both itemsOpacity;
    animation: 0.8s ease-in-out 1 both itemsOpacity;
}
.main.loaded .main__media::before {
    -webkit-animation: 0.8s ease-in-out 1 both blockMove;
    -moz-animation: 0.8s ease-in-out 1 both blockMove;
    animation: 0.8s ease-in-out 1 both blockMove;
}
.main.loaded .intro__headline h1 {
    -webkit-animation: 0.5s cubic-bezier(0.05, 0.74, 0.39, 1) 0.6s 1 both
        fadeInLeft;
    -moz-animation: 0.5s cubic-bezier(0.05, 0.74, 0.39, 1) 0.6s 1 both
        fadeInLeft;
    animation: 0.5s cubic-bezier(0.05, 0.74, 0.39, 1) 0.6s 1 both fadeInLeft;
}
.main.loaded .intro__headline p {
    -webkit-animation: 0.5s cubic-bezier(0.05, 0.74, 0.39, 1) 0.8s 1 both
        fadeInLeft;
    -moz-animation: 0.5s cubic-bezier(0.05, 0.74, 0.39, 1) 0.8s 1 both
        fadeInLeft;
    animation: 0.5s cubic-bezier(0.05, 0.74, 0.39, 1) 0.8s 1 both fadeInLeft;
}
.main.loaded .intro__headline a {
    -webkit-animation: 0.5s cubic-bezier(0.05, 0.74, 0.39, 1) 1s 1 both
        fadeInLeft;
    -moz-animation: 0.5s cubic-bezier(0.05, 0.74, 0.39, 1) 1s 1 both fadeInLeft;
    animation: 0.5s cubic-bezier(0.05, 0.74, 0.39, 1) 1s 1 both fadeInLeft;
}
.main.loaded .intro__logo,
.main.loaded .intro__menu {
    -webkit-animation: 0.5s ease-in-out 1s 1 both fadeIn;
    -moz-animation: 0.5s ease-in-out 1s 1 both fadeIn;
    animation: 0.5s ease-in-out 1s 1 both fadeIn;
}
.main.loaded .media__countdown,
.main.loaded .intro__socials {
    -webkit-animation: 0.5s ease-in-out 1s 1 both fadeIn;
    -moz-animation: 0.5s ease-in-out 1s 1 both fadeIn;
    animation: 0.5s ease-in-out 1s 1 both fadeIn;
}

/* ------------------------------------------------*/
/* Loading Animation End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Animated Backgrounds Start */
/* ------------------------------------------------*/
.video-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden; /* Prevents overflow issues */
}

.video-background video {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Ensures video covers container without distortion */
    display: block; /* Removes any default inline spacing */
}

#video-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    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-monochrome,
#bgndKenburns-color-1,
#bgndKenburns-color-2,
#bgndKenburns-color-3,
#bgndKenburns-color-4 {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    min-height: 100%;
    background-color: transparent;
}

#particles-js,
#nightsky-js,
#snow-js,
#bokeh-js,
#triangles-js {
    position: absolute;
    width: 100%;
    height: 100%;
    min-height: 320px;
    background-color: transparent;
}

/* ------------------------------------------------*/
/* Animated Backgrounds End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Typography Styles Start */
/* ------------------------------------------------*/
h6,
.h6,
h5,
.h5,
h4,
.h4,
h3,
.h3,
h2,
.h2,
h1,
.h1 {
    margin: 0;
    padding: 0;
}

ul,
ol {
    margin: 0;
    padding: 0;
}

h1 {
    display: inline-block;
    position: relative;
    font: normal 800 4rem/1 "Poppins", sans-serif;
    color: #262626;
    margin: 2.4rem 0;
}
h1::before {
    height: 100%;
}
h1.light-text {
    color: #ffffff;
}
@media only screen and (min-width: 768px) {
    h1 {
        font-size: 6rem;
    }
}
@media only screen and (min-width: 1400px) {
    h1 {
        font-size: 9rem;
        margin-bottom: 3.2rem;
    }
}

h2 {
    padding: 0;
    margin: 0;
    font: normal 800 4.8rem/1.2 "Poppins", sans-serif;
    color: #262626;
}
@media only screen and (min-width: 768px) {
    h2 {
        font-size: 6rem;
        margin-bottom: 0;
    }
}
@media only screen and (min-width: 1400px) {
    h2 {
        font-size: 7.6rem;
    }
}

h3 {
    font: normal 700 2rem/1.2 "Poppins", sans-serif;
    text-transform: uppercase;
    color: #262626;
    margin-bottom: 1.8rem;
}
h3 small {
    display: block;
    margin-top: 0.4rem;
    margin-bottom: 0.4rem;
    font: italic 300 1.5rem/1.2 "Libre Baskerville", serif;
    color: #aaa;
    text-transform: none;
}
@media only screen and (min-width: 1400px) {
    h3 {
        font-size: 2rem;
    }
}

h4 {
    font: normal 700 1.8rem/1.2 "Poppins", sans-serif;
    text-transform: uppercase;
    color: #303030;
}
h4 small {
    display: block;
    margin-top: 0.6rem;
    font: italic 300 1.4rem/1.2 "Libre Baskerville", serif;
    text-transform: none;
    letter-spacing: normal;
    color: #303030;
}

.section-title span {
    display: block;
    font: normal 700 2.2rem/1.2 "Poppins", sans-serif;
    margin: 0.6rem 0;
    color: #262626;
}
.section-title span em {
    font-family: "Libre Baskerville", serif;
    font-weight: 400;
}
.section-title p {
    margin: 0;
    margin-top: 1rem;
    font-size: 1.6rem;
    color: #303030;
}
@media only screen and (min-width: 768px) {
    .section-title p {
        margin-top: 1.4rem;
    }
    .section-title span {
        font-size: 2.2rem;
    }
}
@media only screen and (min-width: 1400px) {
    .section-title p {
        margin-top: 1.6rem;
    }
    .section-title span {
        font-size: 2.8rem;
    }
}

p {
    padding: 0;
    margin: 0;
    font: normal 400 1.5rem/1.7 "Poppins", sans-serif;
    color: #303030;
}
p.headline-text {
    font-size: 1.6rem;
    margin-bottom: 3rem;
}
@media only screen and (min-width: 768px) {
    p.headline-text {
        font-size: 1.8rem;
        margin-bottom: 3.2rem;
        max-width: 480px;
    }
}
@media only screen and (min-width: 1400px) {
    p.headline-text {
        margin-bottom: 4.2rem;
        max-width: 540px;
        font-size: 2rem;
    }
}

.contact-data__item p {
    font-size: 1.4rem;
    color: #616161;
}
.contact-data__item a {
    display: block;
    position: relative;
    overflow: hidden;
    text-decoration: none;
    font-size: 1.4rem;
    color: #616161;
    padding: 0 4rem 0 0;
    -webkit-transition: padding 0.5s, color 0.5s ease-in-out;
    -o-transition: padding 0.5s, color 0.5s ease-in-out;
    -moz-transition: padding 0.5s, color 0.5s ease-in-out;
    transition: padding 0.5s, color 0.5s ease-in-out;
}
.contact-data__item a::before {
    content: "";
    display: block;
    position: absolute;
    top: 49%;
    left: -100%;
    width: 2.4rem;
    height: 2px;
    background-color: #343434;
    -webkit-transition: left 0.5s ease-in-out;
    -o-transition: left 0.5s ease-in-out;
    -moz-transition: left 0.5s ease-in-out;
    transition: left 0.5s ease-in-out;
}
.no-touch .contact-data__item a:hover {
    padding: 0 0 0 4rem;
    color: #303030;
}
.no-touch .contact-data__item a:hover::before {
    left: 0;
}

.text-s {
    font-weight: 400;
    font-size: 1.5rem;
}

strong {
    font-weight: 600;
    color: #303030;
}

.txt-light {
    color: #ffffff;
}

.txt-light-transparent {
    color: rgba(255, 255, 255, 0.6);
}

/* ------------------------------------------------*/
/* Typography Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Buttons & Triggers Styles Start */
/* ------------------------------------------------*/
.button {
    position: relative;
    display: inline-block;
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
    -moz-border-radius: 0;
    border-radius: 0;
    font: inherit;
    background-color: transparent;
    cursor: pointer;
    text-decoration: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    overflow: hidden;
    vertical-align: baseline;
    -webkit-transition: padding 0.5s cubic-bezier(0.26, 0.82, 0.76, 1.06);
    -o-transition: padding 0.5s cubic-bezier(0.26, 0.82, 0.76, 1.06);
    -moz-transition: padding 0.5s cubic-bezier(0.26, 0.82, 0.76, 1.06);
    transition: padding 0.5s cubic-bezier(0.26, 0.82, 0.76, 1.06);
}
.button:focus,
.button:active {
    outline: none;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
}
.button::before,
.button::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
}
.button::before {
    left: -100%;
    -webkit-transition: left 0.6s;
    -o-transition: left 0.6s;
    -moz-transition: left 0.6s;
    transition: left 0.6s;
}
.button::after {
    right: 0;
    -webkit-transition: right 0.6s;
    -o-transition: right 0.6s;
    -moz-transition: right 0.6s;
    transition: right 0.6s;
}
.no-touch .button:hover::before {
    left: 0;
}
.no-touch .button:hover::after {
    right: -100%;
}

.button-l {
    height: 52px;
    line-height: 50px;
    padding: 0 5.6rem 0 2.4rem;
    font-size: 1.4rem;
    font-weight: 700;
}
.button-l::before,
.button-l::after {
    width: 4rem;
    height: 2px;
}
.no-touch .button-l:hover {
    padding: 0 2.4rem 0 5.6rem;
}
@media only screen and (min-width: 1200px) {
    .button-l {
        font-size: 1.4rem;
        padding: 0 6rem 0 2.4rem;
    }
    .button-l::before,
    .button-l::after {
        width: 4rem;
    }
    .no-touch .button-l:hover {
        padding: 0 2.4rem 0 6rem;
    }
}

.button-dark-outline {
    border: 2px solid #303030;
    color: #303030;
}
.button-dark-outline::before,
.button-dark-outline::after {
    background-color: #303030;
}
.no-touch .button-dark-outline:hover {
    color: #303030;
}

.button-light {
    color: #303030;
    background-color: #ffffff;
}
.button-light::before,
.button-light::after {
    background-color: #303030;
}

.button-light-outline {
    background-color: transparent;
    border: 1px solid rgba(255, 255, 255, 0.6);
    color: #ffffff;
}
.button-light-outline::before,
.button-light-outline::after {
    background-color: rgba(255, 255, 255, 0.6);
}

.section-close {
    position: relative;
    display: inline-block;
    width: 5rem;
    height: 5rem;
    line-height: 5.4rem;
    font-size: 2.6rem;
    color: #303030;
    text-align: center;
    border: 2px solid #303030;
}
.section-close .material-icons {
    font-size: 2.6rem;
}
.section-close.light {
    color: rgba(255, 255, 255, 0.6);
    border: 2px solid rgba(255, 255, 255, 0.3);
}
.no-touch .section-close:hover {
    color: #303030;
}
.no-touch .section-close:hover.light {
    color: rgba(255, 255, 255, 0.6);
}

/* ------------------------------------------------*/
/* Buttons & Triggers Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Forms & Form Reply Groups Styles Start */
/* ------------------------------------------------*/
.form-container {
    position: relative;
    width: 100%;
    padding: 0 0 6.4rem 0;
}
@media only screen and (min-width: 1200px) {
    .form-container {
        padding: 0;
    }
}

.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.2rem 0.3rem;
    font: normal 400 1.6rem/1.7 "Poppins", sans-serif;
    -webkit-transition: border-bottom 0.6s;
    -o-transition: border-bottom 0.6s;
    -moz-transition: border-bottom 0.6s;
    transition: border-bottom 0.6s;
}
form input {
    height: 5rem;
    margin: 0 0 2.4rem 0;
}
form textarea {
    height: 12rem;
    resize: none;
    margin: 0 0 0.6rem 0;
}
form .inputs-description {
    display: block;
    margin-bottom: 2rem;
    text-align: right;
    font-size: 1.2rem;
}

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

.form-light input,
.form-light textarea {
    font-weight: 300;
}
.form-light ::-webkit-input-placeholder {
    color: rgba(255, 255, 255, 0.6);
}
.form-light :-moz-placeholder {
    color: rgba(255, 255, 255, 0.6);
}
.form-light ::-moz-placeholder {
    color: rgba(255, 255, 255, 0.6);
}
.form-light :-ms-input-placeholder {
    color: rgba(255, 255, 255, 0.6);
}
.form-light input:focus:required:invalid,
.form-light textarea:focus:required:invalid {
    color: #ffffff;
}
.form-light input:required:valid,
.form-light textarea:required:valid {
    color: #ffffff;
}
.form-light input,
.form-light textarea {
    border-bottom: 1px solid #ffffff;
    color: #ffffff;
}
.form-light input:focus,
.form-light textarea:focus {
    border-bottom: 1px solid #b6b6b6;
}
.form-light .inputs-description {
    color: rgba(255, 255, 255, 0.6);
}

.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%);
    max-width: 32rem;
    text-align: center;
    background-color: transparent;
    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;
}
.reply-group .material-icons {
    display: block;
    font-size: 5rem;
    line-height: 1;
}
.reply-group .reply-group__title {
    font-size: 2rem;
    font-weight: 700;
    margin: 0.8rem 0;
}
.reply-group .reply-group__text {
    display: block;
    font-size: 1.5rem;
}

.notify .reply-group {
    width: 100%;
    max-width: none;
    top: 0;
    left: 0;
    -webkit-transform: translateX(0) translateY(0);
    -moz-transform: translateX(0) translateY(0);
    -ms-transform: translateX(0) translateY(0);
    transform: translateX(0) translateY(0);
    background-color: transparent;
    border: none;
    text-align: left;
}

/* ------------------------------------------------*/
/* Forms & Form Reply Groups Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Main Section Styles Start */
/* ------------------------------------------------*/
.main {
    position: relative;
    background-color: rgb(31.2, 31.2, 31.2);
    opacity: 1;
    -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: opacity 0.4s;
    -o-transition: opacity 0.4s;
    -moz-transition: opacity 0.4s;
    transition: opacity 0.4s;
}
.main.is-hidden .main__intro {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}
.main.is-hidden .main__media {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}
.main.notify-is-visible .main__intro {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}
@media only screen and (min-width: 1200px) {
    .main {
        height: 100%;
        min-height: 546px;
        overflow: hidden;
        z-index: 8;
        -webkit-transition: opacity 0.4s, -webkit-transform 0.4s;
        transition: opacity 0.4s, -webkit-transform 0.4s;
        -o-transition: transform 0.4s, opacity 0.4s;
        -moz-transition: transform 0.4s, opacity 0.4s, -moz-transform 0.4s;
        transition: transform 0.4s, opacity 0.4s;
        transition: transform 0.4s, opacity 0.4s, -webkit-transform 0.4s,
            -moz-transform 0.4s;
    }
    .main.is-hidden .main__intro {
        -webkit-transform: translateY(100%);
        -moz-transform: translateY(100%);
        -ms-transform: translateY(100%);
        transform: translateY(100%);
    }
    .main.is-hidden .main__media {
        -webkit-transform: translateY(-100%);
        -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
        transform: translateY(-100%);
    }
    .main.notify-is-visible .main__intro {
        -webkit-transform: translateY(-100%);
        -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
        transform: translateY(-100%);
    }
}

.main__intro {
    position: relative;
    height: auto;
    min-height: 480px;
    padding: 0;
    background-color: rgb(31.2, 31.2, 31.2);
    overflow: hidden;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    -webkit-transition: -webkit-transform 0.6s ease-in-out;
    transition: -webkit-transform 0.6s ease-in-out;
    -o-transition: transform 0.6s ease-in-out;
    -moz-transition: transform 0.6s ease-in-out, -moz-transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out,
        -moz-transform 0.6s ease-in-out;
}
.main__intro::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgb(20.8, 20.8, 20.8);
    -webkit-transform: translateX(-102%);
    -moz-transform: translateX(-102%);
    -ms-transform: translateX(-102%);
    transform: translateX(-102%);
    -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;
    z-index: 1;
}
@media only screen and (min-width: 992px) {
    .main__intro {
        height: 100vh;
        padding: 0;
    }
}
@media only screen and (min-width: 1200px) {
    .main__intro {
        height: 100%;
        min-height: 546px;
    }
}
@media only screen and (min-width: 1400px) {
    .main__intro {
        min-height: 654px;
    }
}

.intro__content {
    position: relative;
    min-height: 480px;
    padding: 180px 0;
    background-color: #ffffff;
}
@media only screen and (min-width: 992px) {
    .intro__content {
        height: 100vh;
        padding: 0;
    }
}
@media only screen and (min-width: 1200px) {
    .intro__content {
        height: 100%;
        min-height: 546px;
    }
}
@media only screen and (min-width: 1400px) {
    .intro__content {
        min-height: 654px;
    }
}

.intro__logo {
    position: absolute;
    top: 4rem;
    left: 10%;
    z-index: 1;
}
.intro__logo img {
    width: auto;
    height: 65px;
}
@media only screen and (min-width: 1200px) {
    .intro__logo {
        position: absolute;
        top: 4rem;
        left: 6.4rem;
    }
}
@media only screen and (min-width: 1400px) {
    .intro__logo {
        position: absolute;
        top: 4.8rem;
        left: 8rem;
    }
}

.intro__menu {
    display: none;
}
@media only screen and (min-width: 1200px) {
    .intro__menu {
        display: block;
        position: absolute;
        top: 4rem;
        right: 6.4rem;
    }
}
@media only screen and (min-width: 1400px) {
    .intro__menu {
        position: absolute;
        top: 4.8rem;
        right: 8rem;
    }
}

.intro__socials {
    position: absolute;
    bottom: 4rem;
    left: 10%;
}
@media only screen and (min-width: 1200px) {
    .intro__socials {
        position: absolute;
        right: auto;
        bottom: 4rem;
        left: 6.4rem;
    }
}
@media only screen and (min-width: 1400px) {
    .intro__socials {
        position: absolute;
        right: auto;
        bottom: 4.8rem;
        left: 8rem;
    }
}

.intro__headline {
    position: relative;
    width: 100%;
    padding: 0 10%;
}
@media only screen and (min-width: 992px) {
    .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%);
    }
}
@media only screen and (min-width: 1200px) {
    .intro__headline {
        padding: 0 6.4rem;
    }
}
@media only screen and (min-width: 1400px) {
    .intro__headline {
        padding: 0 8rem;
    }
}

.main__media {
    position: relative;
    height: 600px;
    overflow: hidden;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    -webkit-transition: -webkit-transform 0.6s ease-in-out;
    transition: -webkit-transform 0.6s ease-in-out;
    -o-transition: transform 0.6s ease-in-out;
    -moz-transition: transform 0.6s ease-in-out, -moz-transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out,
        -moz-transform 0.6s ease-in-out;
}
.main__media::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgb(20.8, 20.8, 20.8);
    -webkit-transform: translateX(-102%);
    -moz-transform: translateX(-102%);
    -ms-transform: translateX(-102%);
    transform: translateX(-102%);
    -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;
    z-index: 1;
}
@media only screen and (min-width: 768px) {
    .main__media {
        height: 760px;
    }
}
@media only screen and (min-width: 1200px) {
    .main__media {
        height: 100%;
        min-height: 546px;
    }
}
@media only screen and (min-width: 1400px) {
    .main__media {
        min-height: 654px;
    }
}

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

.media__countdown {
    position: absolute;
    right: 10%;
    bottom: 4rem;
    opacity: 1;
    -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;
    z-index: 1;
    text-align: right;
}
@media only screen and (min-width: 1200px) {
    .media__countdown {
        position: absolute;
        top: auto;
        right: 6.4rem;
        bottom: 4rem;
        left: auto;
    }
}
@media only screen and (min-width: 1400px) {
    .media__countdown {
        position: absolute;
        right: 8rem;
        bottom: 4.8rem;
        left: auto;
    }
}

/* ------------------------------------------------*/
/* Main Section Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Menu Styles Start */
/* ------------------------------------------------*/
.intro__menu ul {
    display: block;
    position: relative;
}
.intro__menu ul li {
    display: inline-block;
    position: relative;
    margin-right: 32px;
}
.intro__menu ul li:last-of-type {
    margin-right: 0;
}
.intro__menu ul li::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0.8rem;
    left: 0;
    height: 2px;
    width: 0;
    background: #303030;
    -webkit-transition: all 0.5s cubic-bezier(0.26, 0.82, 0.76, 1.06);
    -o-transition: all 0.5s cubic-bezier(0.26, 0.82, 0.76, 1.06);
    -moz-transition: all 0.5s cubic-bezier(0.26, 0.82, 0.76, 1.06);
    transition: all 0.5s cubic-bezier(0.26, 0.82, 0.76, 1.06);
}
.no-touch .intro__menu ul li:hover::after {
    width: 100%;
}
.no-touch .intro__menu ul li:hover a {
    color: #000;
}
.intro__menu ul li a {
    display: block;
    position: relative;
    text-decoration: none;
    font-weight: 700;
    font-size: 1.6rem;
    line-height: 1;
    padding: 2.4rem 0;
    color: #303030;
}

/* ------------------------------------------------*/
/* Menu Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Socials Styles Start */
/* ------------------------------------------------*/
.intro__socials ul {
    margin: 0;
    padding: 0;
    display: block;
    position: relative;
}
.intro__socials ul li {
    display: inline-block;
    margin: 0 2.3rem 0 0;
}
.intro__socials ul li:last-of-type {
    margin: 0;
}
.intro__socials ul li a {
    display: block;
    position: relative;
    font-size: 1.4rem;
    color: #303030;
    -webkit-transition: color 0.3s;
    -o-transition: color 0.3s;
    -moz-transition: color 0.3s;
    transition: color 0.3s;
}
.intro__socials ul li a i {
    font-size: 1.4rem;
}
.no-touch .intro__socials ul li:hover a {
    color: #aaa;
}

/* ------------------------------------------------*/
/* Socials Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Countdown Styles Start */
/* ------------------------------------------------*/
.media__countdown #countdown {
    position: relative;
    font-family: "Poppins", sans-serif;
    font-size: 6rem;
    font-weight: 700;
    line-height: 0.8;
    color: #ffffff;
}
.media__countdown .help-text {
    display: block;
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.2;
    color: #ffffff;
    margin-top: 0.8rem;
}
.media__countdown .countdown-period {
    display: none;
}
@media only screen and (min-width: 1400px) {
    .media__countdown #countdown {
        font-size: 7rem;
    }
}

/* ------------------------------------------------*/
/* Countdown Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Content Sections Styles Start */
/* ------------------------------------------------*/
.inner {
    position: relative;
    width: 100%;
    background-color: transparent;
}
@media only screen and (min-width: 1200px) {
    .inner {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        overflow: hidden;
        z-index: 3;
    }
}

.about .about__info,
.about .about__photo {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}
.about.is-visible .about__info,
.about.is-visible .about__photo,
.about.is-hidden .about__info,
.about.is-hidden .about__photo {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}
@media only screen and (min-width: 1200px) {
    .about .about__info {
        -webkit-transform: translateY(100%);
        -moz-transform: translateY(100%);
        -ms-transform: translateY(100%);
        transform: translateY(100%);
        -webkit-transition: -webkit-transform 0.6s 0s ease-in-out;
        transition: -webkit-transform 0.6s 0s ease-in-out;
        -o-transition: transform 0.6s 0s ease-in-out;
        -moz-transition: transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out,
            -webkit-transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
    }
    .about .about__photo {
        -webkit-transform: translateY(-100%);
        -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
        transform: translateY(-100%);
        -webkit-transition: -webkit-transform 0.6s 0s ease-in-out;
        transition: -webkit-transform 0.6s 0s ease-in-out;
        -o-transition: transform 0.6s 0s ease-in-out;
        -moz-transition: transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out,
            -webkit-transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
    }
    .about.is-visible {
        z-index: 10;
    }
    .about.is-visible .about__info {
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }
    .about.is-visible .about__photo {
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }
    .about.is-hidden .about__info {
        -webkit-transform: translateY(100%);
        -moz-transform: translateY(100%);
        -ms-transform: translateY(100%);
        transform: translateY(100%);
    }
    .about.is-hidden .about__photo {
        -webkit-transform: translateY(-100%);
        -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
        transform: translateY(-100%);
    }
}

.works .works__gallery,
.works .works__info {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}
.works.is-visible .works__gallery,
.works.is-visible .works__info,
.works.is-hidden .works__gallery,
.works.is-hidden .works__info {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}
@media only screen and (min-width: 1200px) {
    .works .works__gallery {
        -webkit-transform: translateY(-100%);
        -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
        transform: translateY(-100%);
        -webkit-transition: -webkit-transform 0.6s 0s ease-in-out;
        transition: -webkit-transform 0.6s 0s ease-in-out;
        -o-transition: transform 0.6s 0s ease-in-out;
        -moz-transition: transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out,
            -webkit-transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
    }
    .works .works__info {
        -webkit-transform: translateY(100%);
        -moz-transform: translateY(100%);
        -ms-transform: translateY(100%);
        transform: translateY(100%);
        -webkit-transition: -webkit-transform 0.6s 0s ease-in-out;
        transition: -webkit-transform 0.6s 0s ease-in-out;
        -o-transition: transform 0.6s 0s ease-in-out;
        -moz-transition: transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out,
            -webkit-transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
    }
    .works.is-visible {
        z-index: 10;
    }
    .works.is-visible .works__gallery {
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }
    .works.is-visible .works__info {
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }
    .works.is-hidden .works__gallery {
        -webkit-transform: translateY(-100%);
        -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
        transform: translateY(-100%);
    }
    .works.is-hidden .works__info {
        -webkit-transform: translateY(100%);
        -moz-transform: translateY(100%);
        -ms-transform: translateY(100%);
        transform: translateY(100%);
    }
}

.contact .contact__info,
.contact .contact__map {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}
.contact.is-visible .contact__info,
.contact.is-visible .contact__map,
.contact.is-hidden .contact__info,
.contact.is-hidden .contact__map {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
}
@media only screen and (min-width: 1200px) {
    .contact .contact__info {
        z-index: 2;
        -webkit-transform: translateY(100%);
        -moz-transform: translateY(100%);
        -ms-transform: translateY(100%);
        transform: translateY(100%);
        -webkit-transition: -webkit-transform 0.6s 0s ease-in-out;
        transition: -webkit-transform 0.6s 0s ease-in-out;
        -o-transition: transform 0.6s 0s ease-in-out;
        -moz-transition: transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out,
            -webkit-transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
    }
    .contact .contact__map {
        z-index: 1;
        -webkit-transform: translateY(-100%);
        -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
        transform: translateY(-100%);
        -webkit-transition: -webkit-transform 0.6s 0s ease-in-out;
        transition: -webkit-transform 0.6s 0s ease-in-out;
        -o-transition: transform 0.6s 0s ease-in-out;
        -moz-transition: transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out;
        transition: transform 0.6s 0s ease-in-out,
            -webkit-transform 0.6s 0s ease-in-out,
            -moz-transform 0.6s 0s ease-in-out;
    }
    .contact.is-visible {
        z-index: 10;
    }
    .contact.is-visible .contact__info {
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }
    .contact.is-visible .contact__map {
        -webkit-transform: translateY(0);
        -moz-transform: translateY(0);
        -ms-transform: translateY(0);
        transform: translateY(0);
    }
    .contact.is-hidden .contact__info {
        -webkit-transform: translateY(100%);
        -moz-transform: translateY(100%);
        -ms-transform: translateY(100%);
        transform: translateY(100%);
    }
    .contact.is-hidden .contact__map {
        -webkit-transform: translateY(-100%);
        -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
        transform: translateY(-100%);
    }
    .contact.popup-is-visible .contact__info {
        -webkit-transform: translateY(-100%);
        -moz-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
        transform: translateY(-100%);
    }
}

.scroll {
    position: relative;
    -webkit-transform: translateZ(0);
    -moz-transform: translateZ(0);
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    -moz-backface-visibility: hidden;
    backface-visibility: hidden;
    background-color: #ffffff;
}
.scroll::after {
    display: none;
    content: "";
}
@media only screen and (min-width: 1200px) {
    .scroll {
        height: 100%;
        overflow-y: auto;
    }
    .scroll::after {
        content: "custom-scrollbar";
    }
}

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

.blocks {
    position: relative;
    padding: 6.4rem 0 6.4rem 0;
    background-color: #ffffff;
}
.blocks.no-padding-bottom {
    padding-bottom: 0;
}
@media only screen and (min-width: 768px) {
    .blocks {
        padding: 8rem 0 6.4rem 0;
    }
}
@media only screen and (min-width: 1200px) {
    .blocks {
        padding: 6.4rem 0 8rem 0;
    }
}

.blocks__single {
    position: relative;
    width: 100%;
    margin-bottom: 6.4rem;
    padding: 0 10%;
}
.blocks__single:last-of-type {
    margin-bottom: 0;
}
.blocks__single.no-padding {
    padding: 0;
}
.blocks__single.no-margin {
    margin-bottom: 0;
}
@media only screen and (min-width: 1200px) {
    .blocks__single {
        padding: 0 6.4rem;
    }
}
@media only screen and (min-width: 1400px) {
    .blocks__single {
        padding: 0 8rem;
    }
}

.section-controls {
    display: none;
}
@media only screen and (min-width: 1200px) {
    .section-controls {
        display: block;
        overflow: hidden;
        margin-bottom: 4.8rem;
        padding: 0 6.4rem;
    }
}
@media only screen and (min-width: 1400px) {
    .section-controls {
        padding: 0 8rem;
    }
}

.contact-buttons {
    position: relative;
    padding: 0 10%;
}
@media only screen and (min-width: 1200px) {
    .contact-buttons {
        padding: 0 6.4rem;
    }
}
@media only screen and (min-width: 1400px) {
    .contact-buttons {
        padding: 0 8rem;
    }
}

.about__photo {
    height: 600px;
    background-repeat: no-repeat;
    background-position: center center;
    -moz-background-size: cover;
    background-size: cover;
}
@media only screen and (min-width: 768px) {
    .about__photo {
        height: 760px;
    }
}
@media only screen and (min-width: 1200px) {
    .about__photo {
        height: 100%;
    }
}

/* ------------------------------------------------*/
/* Content Sections Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Custom Scroll Styles Start */
/* ------------------------------------------------*/
.mCSB_scrollTools {
    opacity: 1;
}

.mCSB_scrollTools .mCSB_draggerRail {
    filter: "alpha(opacity=100)";
}

.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar {
    filter: "alpha(opacity=100)";
}

.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar {
    filter: "alpha(opacity=100)";
}

.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar {
    filter: "alpha(opacity=100)";
}

.mCSB_inside > .mCSB_container {
    margin-right: 4px;
}

.scroll-left .mCSB_inside > .mCSB_container {
    margin-right: 0;
    margin-left: 0;
}
@media only screen and (min-width: 1200px) {
    .scroll-left .mCSB_inside > .mCSB_container {
        margin-left: 4px;
    }
}

.mCSB_container.mCS_no_scrollbar_y.mCS_y_hidden {
    margin-right: 0;
}

.mCS-dir-rtl > .mCSB_inside > .mCSB_container {
    margin-right: 0;
    margin-left: 30px;
}

.mCS-dir-rtl > .mCSB_inside > .mCSB_container.mCS_no_scrollbar_y.mCS_y_hidden {
    margin-left: 0;
}

.mCSB_scrollTools {
    position: absolute;
    width: 4px;
    height: auto;
    left: auto;
    top: 0;
    right: 0;
    bottom: 0;
}

.scroll-left .mCSB_scrollTools {
    left: 0;
    top: 0;
    right: auto;
    bottom: 0;
}

.mCSB_outside + .mCSB_scrollTools {
    right: -26px;
}

.mCS-dir-rtl > .mCSB_inside > .mCSB_scrollTools,
.mCS-dir-rtl > .mCSB_outside + .mCSB_scrollTools {
    right: auto;
    left: 0;
}

.mCS-dir-rtl > .mCSB_outside + .mCSB_scrollTools {
    left: -26px;
}

.mCSB_scrollTools .mCSB_draggerContainer {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    height: auto;
}

.mCSB_scrollTools a + .mCSB_draggerContainer {
    margin: 20px 0;
}

.mCSB_scrollTools .mCSB_draggerRail {
    width: 4px;
    height: 100%;
    margin: 0 auto;
    -moz-border-radius: 0;
    border-radius: 0;
}

.mCSB_scrollTools .mCSB_dragger {
    cursor: pointer;
    width: 100%;
    height: 30px;
    z-index: 1;
}

.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar {
    position: relative;
    width: 4px;
    height: 100%;
    margin: 0 auto;
    text-align: center;
    -moz-border-radius: 0;
    border-radius: 0;
}

.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand
    .mCSB_dragger.mCSB_dragger_onDrag_expanded
    .mCSB_dragger_bar,
.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand
    .mCSB_draggerContainer:hover
    .mCSB_dragger
    .mCSB_dragger_bar {
    width: 12px;
}

.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand
    .mCSB_dragger.mCSB_dragger_onDrag_expanded
    + .mCSB_draggerRail,
.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand
    .mCSB_draggerContainer:hover
    .mCSB_draggerRail {
    width: 8px;
}

.mCSB_scrollTools .mCSB_buttonUp,
.mCSB_scrollTools .mCSB_buttonDown {
    display: block;
    position: absolute;
    height: 20px;
    width: 100%;
    overflow: hidden;
    margin: 0 auto;
    cursor: pointer;
}

.mCSB_scrollTools .mCSB_buttonDown {
    bottom: 0;
}

/* Scroll Custom Colors */
.mCSB_draggerContainer {
    background: #cecece;
}

.mCSB_scrollTools .mCSB_draggerRail {
    background-color: #cecece;
}

.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar {
    background-color: #303030;
}

.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar {
    background-color: #303030;
}

.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar {
    background-color: #303030;
}

/* ------------------------------------------------*/
/* Custom Scroll Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Section Title Styles Start */
/* ------------------------------------------------*/
.section-title {
    position: relative;
    width: 100%;
    padding: 0 10%;
    margin: 0 0 4.8rem 0;
}
@media only screen and (min-width: 1200px) {
    .section-title {
        width: 100%;
        padding: 0 6.4rem;
        margin: 0 0 4.8rem 0;
    }
}
@media only screen and (min-width: 1400px) {
    .section-title {
        padding: 0 8rem;
        margin: 0 0 6.4rem 0;
    }
}

/* ------------------------------------------------*/
/* Section Title Styles Start */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Features Styles Start */
/* ------------------------------------------------*/
.features__item {
    position: relative;
    text-align: center;
}

.features__image {
    height: 300px;
    position: relative;
    background-repeat: no-repeat;
    background-position: center center;
    -moz-background-size: cover;
    background-size: cover;
}
@media only screen and (min-width: 768px) {
    .features__image {
        height: 380px;
    }
}

.features__descr {
    position: relative;
}

.descr__container {
    padding: 6.4rem 10%;
}
@media only screen and (min-width: 768px) {
    .descr__container {
        position: absolute;
        width: 100%;
        left: 0;
        top: 50%;
        bottom: auto;
        -webkit-transform: translateY(-50%);
        -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        padding: 0 8rem;
    }
}

/* ------------------------------------------------*/
/* Features Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Blockquote Styles Start */
/* ------------------------------------------------*/
.blockquote {
    position: relative;
    min-height: 600px;
    padding: 6.4rem 10%;
    background-repeat: no-repeat;
    background-position: bottom center;
    -moz-background-size: cover;
    background-size: cover;
}
@media only screen and (min-width: 768px) {
    .blockquote {
        min-height: 760px;
    }
}
@media only screen and (min-width: 1200px) {
    .blockquote {
        padding: 6.4rem 8rem;
    }
}

.blockquote__content {
    position: relative;
    padding: 8rem 0 0 0;
    z-index: 1;
    max-width: 660px;
}
.blockquote__content blockquote {
    display: block;
    position: relative;
}
.blockquote__content blockquote p {
    margin: 0 0 2.4rem 0;
    font-family: "Libre Baskerville", serif;
    font-size: 2rem;
    color: #303030;
}
.blockquote__content blockquote cite {
    font-size: 1.4rem;
    color: #616161;
}
.blockquote__content blockquote cite span {
    display: block;
}
@media only screen and (min-width: 768px) {
    .blockquote__content {
        padding: 8.8rem 0 0 0;
    }
    .blockquote__content::after {
        font-size: 6rem;
    }
    .blockquote__content blockquote p {
        font-size: 2.8rem;
    }
}

.blockquote__icon {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    font-size: 4.8rem;
    line-height: 1;
    color: rgba(48, 48, 48, 0.1);
}
@media only screen and (min-width: 768px) {
    .blockquote__icon {
        font-size: 5.4rem;
    }
}

/* ------------------------------------------------*/
/* Blockquote Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Team Styles Start */
/* ------------------------------------------------*/
.team {
    position: relative;
}

.team__item {
    position: relative;
    margin-bottom: 4.8rem;
}
.team__item:last-of-type {
    margin-bottom: 0;
}
.team__item img {
    display: block;
}
.team__item h3 {
    margin-top: 2.4rem;
    margin-bottom: 1.6rem;
}
.team__item h3 small {
    margin-bottom: 0;
}
@media only screen and (min-width: 576px) {
    .team__item {
        margin-bottom: 0;
    }
}

.team__socials {
    display: block;
    margin: 0;
    padding: 0;
    margin-top: 1rem;
}
.team__socials li {
    display: inline-block;
    margin: 0 1.6rem 0 0;
    padding: 0;
}
.team__socials li:last-of-type {
    margin: 0;
}
.team__socials li a {
    display: block;
    position: relative;
    height: 2.4rem;
    font: normal 400 1.4rem/2.4rem "Poppins", sans-serif;
    color: #aaa;
    -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;
}
.team__socials li a i {
    line-height: 0;
}
@media only screen and (min-width: 768px) {
    .team__socials {
        margin-top: 1.6rem;
    }
}
@media only screen and (min-width: 992px) {
    .no-touch .team__socials li:hover a {
        color: #303030;
    }
}

/* ------------------------------------------------*/
/* Team Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Gallery Styles Start */
/* ------------------------------------------------*/
.works__gallery {
    position: relative;
}

.my-gallery__item {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
    overflow: hidden;
    cursor: pointer;
}
.my-gallery__item::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #ffffff;
    background: -webkit-gradient(
        linear,
        left top,
        left bottom,
        from(rgba(255, 255, 255, 0)),
        color-stop(50%, rgba(255, 255, 255, 0)),
        to(rgba(255, 255, 255, 0.6))
    );
    background: -moz-linear-gradient(
        top,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0) 50%,
        rgba(255, 255, 255, 0.6) 100%
    );
    background: -o-linear-gradient(
        top,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0) 50%,
        rgba(255, 255, 255, 0.6) 100%
    );
    background: linear-gradient(
        to bottom,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0) 50%,
        rgba(255, 255, 255, 0.6) 100%
    );
    opacity: 1;
    -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
    transition: opacity 0.5s, -webkit-transform 0.5s;
    -o-transition: transform 0.5s, opacity 0.5s;
    -moz-transition: transform 0.5s, opacity 0.5s, -moz-transform 0.5s;
    transition: transform 0.5s, opacity 0.5s;
    transition: transform 0.5s, opacity 0.5s, -webkit-transform 0.5s,
        -moz-transform 0.5s;
}
.my-gallery__item:nth-of-type(2)::after,
.my-gallery__item:nth-of-type(3)::after {
    background-color: #292929;
    background: -webkit-gradient(
        linear,
        left top,
        left bottom,
        from(rgba(41, 41, 41, 0)),
        color-stop(50%, rgba(41, 41, 41, 0)),
        to(rgba(41, 41, 41, 0.6))
    );
    background: -moz-linear-gradient(
        top,
        rgba(41, 41, 41, 0) 0%,
        rgba(41, 41, 41, 0) 50%,
        rgba(41, 41, 41, 0.6) 100%
    );
    background: -o-linear-gradient(
        top,
        rgba(41, 41, 41, 0) 0%,
        rgba(41, 41, 41, 0) 50%,
        rgba(41, 41, 41, 0.6) 100%
    );
    background: linear-gradient(
        to bottom,
        rgba(41, 41, 41, 0) 0%,
        rgba(41, 41, 41, 0) 50%,
        rgba(41, 41, 41, 0.6) 100%
    );
}
.my-gallery__item figcaption {
    position: absolute;
    top: 3.2rem;
    left: 3.2rem;
    width: -moz-calc(100% - 6.4rem);
    width: calc(100% - 6.4rem);
    height: -moz-calc(100% - 6.4rem);
    height: calc(100% - 6.4rem);
    z-index: 1;
}
.my-gallery__item h4 {
    position: absolute;
    bottom: 0;
    left: 0;
    color: #303030;
    opacity: 1;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
    -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
    transition: opacity 0.5s, -webkit-transform 0.5s;
    -o-transition: transform 0.5s, opacity 0.5s;
    -moz-transition: transform 0.5s, opacity 0.5s, -moz-transform 0.5s;
    transition: transform 0.5s, opacity 0.5s;
    transition: transform 0.5s, opacity 0.5s, -webkit-transform 0.5s,
        -moz-transform 0.5s;
}
.my-gallery__item h4 small {
    color: #303030;
}
.my-gallery__item p {
    display: none;
}
.my-gallery__item:nth-of-type(2) figcaption h4,
.my-gallery__item:nth-of-type(3) figcaption h4 {
    color: #ffffff;
}
.my-gallery__item:nth-of-type(2) figcaption h4 small,
.my-gallery__item:nth-of-type(3) figcaption h4 small {
    color: rgba(255, 255, 255, 0.8);
}
@media only screen and (min-width: 1200px) {
    .my-gallery__item {
        height: 50vh;
    }
    .my-gallery__item::after {
        background-color: #ffffff;
        opacity: 0;
        -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
        transition: opacity 0.5s, -webkit-transform 0.5s;
        -o-transition: transform 0.5s, opacity 0.5s;
        -moz-transition: transform 0.5s, opacity 0.5s, -moz-transform 0.5s;
        transition: transform 0.5s, opacity 0.5s;
        transition: transform 0.5s, opacity 0.5s, -webkit-transform 0.5s,
            -moz-transform 0.5s;
    }
    .my-gallery__item:nth-of-type(2)::after,
    .my-gallery__item:nth-of-type(3)::after {
        background-color: #292929;
    }
    .my-gallery__item img {
        width: auto;
        height: 50vh;
    }
    .my-gallery__item figcaption h4 {
        opacity: 0;
        -webkit-transform: translateX(-1.6rem);
        -moz-transform: translateX(-1.6rem);
        -ms-transform: translateX(-1.6rem);
        transform: translateX(-1.6rem);
        -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
        transition: opacity 0.5s, -webkit-transform 0.5s;
        -o-transition: transform 0.5s, opacity 0.5s;
        -moz-transition: transform 0.5s, opacity 0.5s, -moz-transform 0.5s;
        transition: transform 0.5s, opacity 0.5s;
        transition: transform 0.5s, opacity 0.5s, -webkit-transform 0.5s,
            -moz-transform 0.5s;
    }
    .no-touch .my-gallery__item:hover::after {
        opacity: 1;
    }
    .no-touch .my-gallery__item:hover figcaption h4 {
        -webkit-transform: translateX(0);
        -moz-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
        opacity: 1;
    }
}

.my-gallery__link {
    position: relative;
    float: left;
    width: 100%;
    height: 100%;
    overflow: hidden;
    text-align: center;
}
.my-gallery__link .picture {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-position: center center;
    -moz-background-size: cover;
    background-size: cover;
    -webkit-transition: background-position 0.5s;
    -o-transition: background-position 0.5s;
    -moz-transition: background-position 0.5s;
    transition: background-position 0.5s;
}

.my-gallery__image {
    opacity: 1;
}
@media only screen and (min-width: 1200px) {
    .my-gallery__image {
        opacity: 0;
    }
}

.pswp__caption__center h4 {
    margin-bottom: 1.6rem;
    font: normal 700 1.8rem/20px "Poppins", sans-serif;
    color: #ffffff;
    text-transform: uppercase;
}
.pswp__caption__center h4 small {
    display: block;
    padding-top: 0.8rem;
    margin: 0;
    font: normal 400 1.4rem/20px "Libre Baskerville", serif;
    color: rgba(255, 255, 255, 0.8);
    text-transform: none;
}
.pswp__caption__center p {
    font: normal 300 1.4rem/1.6 "Poppins", sans-serif;
    color: rgba(255, 255, 255, 0.6);
}

.pswp__counter {
    font-family: "Poppins", sans-serif;
}

.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: #292929;
}

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

.pswp__button--close {
    background-color: #ffffff;
}

/* ------------------------------------------------*/
/* Gallery Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Contact Data Styles Start */
/* ------------------------------------------------*/
.contact-data {
    position: relative;
    margin-bottom: 2.4rem;
}

.contact-data__item {
    margin-bottom: 2.4rem;
}
.contact-data__item span {
    text-align: left;
    margin-bottom: 0.8rem;
    font-size: 22px;
    line-height: 1;
    color: #303030;
}

/* ------------------------------------------------*/
/* Contact Data Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Google Map Styles Start */
/* ------------------------------------------------*/
.contact__map {
    height: 600px;
}
@media only screen and (min-width: 768px) {
    .contact__map {
        height: 760px;
    }
}
@media only screen and (min-width: 1200px) {
    .contact__map {
        height: 100%;
    }
}

.map {
    position: relative;
}

#google-container {
    position: relative;
    width: 100%;
    height: 600px;
}
@media only screen and (min-width: 768px) {
    #google-container {
        height: 760px;
    }
}
@media only screen and (min-width: 1200px) {
    #google-container {
        height: 100vh;
    }
}

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

#zoom-in,
#zoom-out {
    position: relative;
    height: 4rem;
    width: 4rem;
    line-height: 4rem;
    cursor: pointer;
    margin-left: 3.2rem;
    background-color: rgba(255, 255, 255, 0.4);
    color: #303030;
    border: 2px solid #303030;
    font-size: 2rem;
    -webkit-transition: background-color 0.3s;
    -o-transition: background-color 0.3s;
    -moz-transition: background-color 0.3s;
    transition: background-color 0.3s;
}
#zoom-in span,
#zoom-out span {
    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.8rem;
    margin-bottom: 2rem;
}

/* ------------------------------------------------*/
/* Google Map Styles End */
/* ------------------------------------------------*/
/* ------------------------------------------------*/
/* Popup Forms Styles Start */
/* ------------------------------------------------*/
.notify {
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    overflow-y: auto;
    z-index: 10;
    padding: 0;
    background-color: #24262b;
    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: -webkit-transform 0.6s ease-in-out;
    transition: -webkit-transform 0.6s ease-in-out;
    -o-transition: transform 0.6s ease-in-out;
    -moz-transition: transform 0.6s ease-in-out, -moz-transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out,
        -moz-transform 0.6s ease-in-out;
}
.notify.is-visible {
    -webkit-transform: translateX(0) translateY(0);
    -moz-transform: translateX(0) translateY(0);
    -ms-transform: translateX(0) translateY(0);
    transform: translateX(0) translateY(0);
}
@media only screen and (min-width: 1200px) {
    .notify {
        position: fixed;
        top: 0;
        right: auto;
        left: 0;
        width: 50%;
        -webkit-transform: translateX(0) translateY(100%);
        -moz-transform: translateX(0) translateY(100%);
        -ms-transform: translateX(0) translateY(100%);
        transform: translateX(0) translateY(100%);
    }
    .notify.is-visible {
        -webkit-transform: translateX(0) translateY(0);
        -moz-transform: translateX(0) translateY(0);
        -ms-transform: translateX(0) translateY(0);
        transform: translateX(0) translateY(0);
    }
}

.popup__controls {
    padding: 4rem 10% 0 10%;
}
@media only screen and (min-width: 1200px) {
    .popup__controls {
        padding: 4rem 6.4rem 0 6.4rem;
    }
}
@media only screen and (min-width: 1400px) {
    .popup__controls {
        padding: 4.8rem 8rem 0 8rem;
    }
}

.popup__content {
    position: relative;
    width: 100%;
}

@media only screen and (min-width: 1200px) {
    .popup__content {
        position: absolute;
        top: 50%;
        bottom: auto;
        -webkit-transform: translateY(-50%);
        -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
    }
}

.popup__title {
    padding: 4.8rem 10% 2.4rem 10%;
}
.close_modal_btn {
    padding: 4.8rem 10% 2.4rem 10%;
}
.popup__title .title {
    font: normal 700 2.4rem/1.2 "Poppins", sans-serif;
    text-transform: uppercase;
    margin-bottom: 1.6rem;
}
@media only screen and (min-width: 1200px) {
    .popup__title {
        padding: 4.8rem 6.4rem 2.4rem 6.4rem;
    }
}
@media only screen and (min-width: 1400px) {
    .popup__title {
        padding: 4.8rem 8rem 2.4rem 8rem;
    }
}

.writealine {
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    overflow-y: auto;
    z-index: 10;
    padding: 0;
    background-color: #24262b;
    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: -webkit-transform 0.6s ease-in-out;
    transition: -webkit-transform 0.6s ease-in-out;
    -o-transition: transform 0.6s ease-in-out;
    -moz-transition: transform 0.6s ease-in-out, -moz-transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out;
    transition: transform 0.6s ease-in-out, -webkit-transform 0.6s ease-in-out,
        -moz-transform 0.6s ease-in-out;
}
.writealine.is-visible {
    -webkit-transform: translateX(0) translateY(0);
    -moz-transform: translateX(0) translateY(0);
    -ms-transform: translateX(0) translateY(0);
    transform: translateX(0) translateY(0);
}
@media only screen and (min-width: 1200px) {
    .writealine {
        position: fixed;
        top: 0;
        right: 0;
        width: 50%;
        -webkit-transform: translateX(0) translateY(100%);
        -moz-transform: translateX(0) translateY(100%);
        -ms-transform: translateX(0) translateY(100%);
        transform: translateX(0) translateY(100%);
    }
    .writealine.is-visible {
        -webkit-transform: translateX(0) translateY(0);
        -moz-transform: translateX(0) translateY(0);
        -ms-transform: translateX(0) translateY(0);
        transform: translateX(0) translateY(0);
    }
}

/* ------------------------------------------------*/
/* Popup Forms Styles End */
/* ------------------------------------------------*/


/* ------------------------------------------------*/
/* PRIVACY MODAL STYLES
/* ------------------------------------------------*/

.popup.privacy-policy {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    background: rgba(0, 0, 0, 0.95);
}

.popup.privacy-policy .popup__content {
    position: relative;
    background: #fff;
    border-radius: 1rem;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
    width: 80%;
    max-height: 90vh;
    margin: auto;
    top: 50%;
    transform: translateY(-50%);
    padding: 2rem;
    display: flex;
    flex-direction: column;
}

.popup.privacy-policy .popup__controls {
    position: absolute;
    top: -15px;
    right: -15px;
    z-index: 10001;
}

.popup.privacy-policy .section-close {
    color: #333;
    font-size: 1.5rem;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
    transition: all 0.3s ease;
}

.popup.privacy-policy .section-close:hover {
    color: #007bff;
    transform: scale(1.1);
    box-shadow: 0 3px 15px rgba(0, 0, 0, 0.3);
}

.popup.privacy-policy .blocks__single {
    overflow-y: auto;
    padding-right: 0.5rem;
    scrollbar-width: thin;
    flex-grow: 1;
}

.popup.privacy-policy .blocks__single::-webkit-scrollbar {
    width: 8px;
}

.popup.privacy-policy .blocks__single::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 10px;
}

.popup.privacy-policy .blocks__single::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 10px;
}

.popup.privacy-policy .blocks__single::-webkit-scrollbar-thumb:hover {
    background: #555;
}

.popup.privacy-policy .button-l {
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    border-radius: 0.5rem;
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    color: #212529;
    transition: all 0.3s ease;
    margin-top: 1.5rem;
}

/* Dark mode */
@media (prefers-color-scheme: dark) {
    .popup.privacy-policy .popup__content {
        background: #1a202c;
    }

    .popup.privacy-policy .section-close {
        color: #fff;
        background: #2d3748;
    }

    .popup.privacy-policy .section-close:hover {
        color: #4dabf7;
        background: #4a5568;
    }

    .popup.privacy-policy .blocks__single {
        color: #e2e8f0;
    }

    .popup.privacy-policy .blocks__single::-webkit-scrollbar-track {
        background: #2d3748;
    }

    .popup.privacy-policy .blocks__single::-webkit-scrollbar-thumb {
        background: #4a5568;
    }

    .popup.privacy-policy .blocks__single::-webkit-scrollbar-thumb:hover {
        background: #718096;
    }

    .popup.privacy-policy .button-l {
        background: #2d3748;
        border-color: #4a5568;
        color: #e2e8f0;
    }

    .popup.privacy-policy .button-l:hover {
        background: #4a5568;
        border-color: #718096;
    }
}

/* Mobile adjustments */
@media (max-width: 768px) {
    .popup.privacy-policy .popup__content {
        width: 100%;
        height: 100vh;
        max-height: 100vh;
        margin: 0;
        top: 0;
        transform: none;
        padding: 1rem;
        border-radius: 0;
        display: flex;
        flex-direction: column;
    }

    .popup.privacy-policy .blocks__single {
        max-height: calc(100vh - 200px); /* Adjust to leave space for title + button */
        overflow-y: auto;
        margin-top: 1rem;
    }

    .popup.privacy-policy .text-center.mt-6 {
        margin-top: 1rem;
    }
}

.form-check {
  position: relative;
}

#privacy-error {
  position: absolute;
  bottom: -1.5rem;
  left: 0;
  width: 100%;
  font-size: 0.875rem;
}

@media (max-width: 768px) {
  #privacy-error {
    position: static;
    margin-top: 0.5rem;
  }
}