/* ==============================================================

Project: 	Axis - Responsive Coming Soon WordPress Plugin
Info:		https://codecanyon.net/item/axis-responsive-coming-soon-wordpress-plugin/19576948
Version: 	1.9
Author:		AthenaStudio
Profile:	https://themeforest.net/user/athenastudio

-----------------------------------------------------------------
					*** TABLE OF CONTENTS ***
-----------------------------------------------------------------

	1.	General
	2.	Back stretch
	3.	Youtube player
	4.	Page loader
	5.	Header
	6.	Countdown
	7.	Subscribe
	8.	Services
	9.  Contact info
	10.	Contact form
	11.	Google maps
	12.	Footer
		
=============================================================*/

/*********************
    - 1. General -
*********************/
html {
	font-size:100%;
	-webkit-font-smoothing:antialiased;
	-webkit-text-size-adjust:100%;
		-ms-text-size-adjust:100%;	
}

html, body {
	font-family:"Open Sans", sans-serif;
	line-height:1.75;
	margin:0;
	padding:0;
	width:100%;
	height:100%;
	-webkit-font-smoothing:antialiased;
}

a {
    text-decoration:none;
    transition:all 0.3s;
}

a:hover {
    text-decoration:none;
}

/**************************
    - 2. Back stretch -
**************************/
.backstretch:after {
	content:'';
	position:absolute;
	left:0;
	top:0;
	right:0;
	bottom:0;
	background-image:url('../images/overlay.png'); 
	background-color:rgba(95, 96, 96, 0.4);
	z-index:1;
}

/****************************
    - 3. Youtube player -
****************************/
.mbYTP_wrapper:after {
	content:'';
	position:absolute;
	left:0;
	top:0;
	right:0;
	bottom:0;
	z-index:1;
	background-image:url('../images/overlay.png'); 
	background-color:rgba(95, 96, 96, 0.4);
}

.player-controls {
	position:absolute;
	top:190px;
	right:25%;
}

.player-controls a {
	background:none;
	color:#fff !important;
	outline:none;
	width:30px;
	margin:5px;
	border:1px solid #F8F8F8;
	height:30px;
	line-height:28px;
    font-size:12px;
	text-decoration:none !important;
	border-radius:50%;
	transition:all 0.3s ease-in-out !important;
}

.player-controls a:hover {
	color:#fff;
	text-decoration:none !important;
	transition:all 0.3s ease-in-out !important;
}

/*************************
    - 4. Page loader -
*************************/
.page-loader {
	position:fixed;
	display:block;
	width:100%;
	height:100%;
	top:0;
	right:0;
	left:0;
	bottom:0;
	z-index:40;
	background:#fff;
}

.page-loader .progress {
	margin:-12em 0 0 -12em;
	width:50px;
	height:50px;
	font-size:2px;
	position:absolute;
	text-indent:-9999em;
	top:50vh;
	left:50vw;
	background:#fff;
	border-top:0.8em solid rgba(35, 35, 35, 0.2);
	border-right:0.8em solid rgba(35, 35, 35, 0.2);
	border-bottom:0.8em solid rgba(35, 35, 35, 0.2);
	border-left:0.8em solid #000;
	transform:translateZ(0);
	animation:preloader 0.7s infinite linear;
}

.page-loader .progress,  .page-loader .progress:after {
	border-radius:50%;
	width:24em;
	height:24em;
}

.page-loader.overlay {
	background:rgba(0, 0, 0, 0.5);
}

.page-loader.overlay .progress {
	background:transparent;	
}

@keyframes preloader {
 	0% 		{transform:rotate(0deg);}	
 	100% 	{transform:rotate(360deg);}
}

/********************
    - 5. Header -
********************/
header {
	height:100%;
	text-align:center;
}

header h1 {
	font-size:36px;
	color:#fff;
	font-weight:300;
	letter-spacing:1px;
	padding-top:10px;
	padding-bottom:10px;
	font-family:"Open Sans", sans-serif;
	text-transform:uppercase;
}

header h1 > span {
	font-weight:700;	
}

header p {
    font-size:14px;
	color:rgba(237, 237, 237, 0.9);
	word-spacing:1px; 
	line-height:1.5em;
	padding-bottom:10px;
}

/* Table */
.table {
	display:table;
	width:100%;
	height:100%;
	vertical-align:middle;
}

.table-cell {
	display:table-cell;
	width:100%;
	height:100%;
	vertical-align:middle;
}

.table > :not(caption) > * > * {
	padding:0 !important;
}

/* Magic mouse */
header .mouse {
	position:absolute;
	width:26px;
	height:40px;
	border:2px solid #fff;
	border-radius:15px;
	background:transparent;
	bottom:30px;
	margin:0 auto;
	left:0;
	right:0;
}

header .mouse .wheel {
	width:6px;
	height:6px;
	background-color:#fff;
	border-radius:50%;
	margin-left:auto;
	margin-right:auto;
	margin-top:6px;
	left:0;
	right:0;
	animation:magic-mouse 1.7s infinite ease;
}

@keyframes magic-mouse {
 	0% {
 		margin-top:6px;
 		opacity:0;
	}
	
 	30% {
 		opacity:1;
	}
	
 	100% {
 		margin-top:18px;
 		opacity:0;
	}
}

@-webkit-keyframes magic-mouse {
 	0% {
 		margin-top:6px;
 		opacity:0;
	}
	
 	30% {
 		opacity:1;
	}
	
 	100% {
 		margin-top:18px;
 		opacity:0;
	}
}

/***********************
    - 6. Countdown -
***********************/
.countdown {
    display:inline-block;
	margin:0 auto;
	font-size:4em;
    font-family:'Open Sans', sans-serif;
	font-weight:700;
    line-height:65px;
    color:#fff;
}

.countdown div span {
	display:block;
	font-weight:normal;
    font-size:16px;
    line-height:19px;
	color:rgba(237, 237, 237, 0.8);
}

.countdown div {
	position:relative;
	display:inline-block;
    margin:0 34px;	
}

.countdown div:after {
	content:"";
	position:absolute;
	top:22px;
	right:-34px;
	width:1px;
	height:60%;
	background:#fff;
	opacity:0.3;
}

.countdown div:last-child:after {
	display:none;
}

/***********************
    - 7. Subscribe -
***********************/
.subscribe p {
	font-size:14px;
	color:#fff;
	font-weight:300;
	letter-spacing:1px;
	margin-top:22px;
	padding:0;
	text-transform:uppercase;
	font-family:"Open Sans", sans-serif;
}

.subscribe form {
	display:inline-block;
	position:relative;
}

.subscribe input[type=text] { 
	width:340px;
	color:#fff;
	background:transparent;
	border:1px solid rgba(255, 255, 255, 0.3);
	outline:0;
	height:41px;
	padding:6px 50px 6px 12px;
	border-radius:3px;
    transition:all 0.3s !important;
}

.subscribe button {
	background:none;
	cursor:pointer;
	color:#fff;
	font-size:15px;
	border:0;
	position:absolute;
	top:7px;
	right:9px;
    transition:all 0.3s !important;
}

.subscribe label {
	display:block !important;
	float:none;
	top:0;
	height:2.5em;
	padding:15px 20px;
	color:#ededed;
	font-size:13px;
	font-weight:100;
}

.subscribe label i.fa-check {
	padding-top:15px;
}

.form-field {
	position:relative;
	margin:0 !important;
	padding:0 !important;
}

.form-field p.error {
	position:absolute;
	top:45px;
	color:#fff;
	font-size:10px;
	padding:2px 0;
	text-transform:uppercase;
	border-radius:3px;
}

.subscribe .success {
	color:#dadada;
	min-height:42px;
	text-align:center;
}

/**********************
    - 8. Services -
**********************/
.services {
	padding:80px 0;
	background-color:#fff;
	z-index:10;
}

.section-title {
	position:relative;
	font-size:32px;
	font-weight:400;
	color:#000;
	text-align:center;
	letter-spacing:1px;  
	text-transform:uppercase;
	padding:0 0 25px 0;	
	margin:0 0 20px 0;
	font-family:"Open Sans", sans-serif;
}

.section-title > span {
	font-weight:700;
}

.section-title:after {
    content:"";
	position:absolute;
    display:block;   
    bottom:0;
    left:0;
    right:0;
	width:70px;
    height:2px;
    margin:0 auto;
}

.section-info {
	margin-top:10px;
	color:#696f6f;
	font-size:20px;
	font-weight:300;
	text-align:center;
	margin:0 0 60px 0;
	font-family:"Open Sans", sans-serif;
}

.services .icon {
	display:block;
	overflow:hidden;
	height:140px;
	margin:0 auto 40px auto;
}

.services .icon i {
	position:relative;
	display:block;
	width:140px; 
	height:140px;  
	line-height:140px; 
	max-width:100%;  
	margin:0 auto;
	background:#fff;
	font-size:60px;
	border-radius:50%;  
	cursor:default;
	transition:all 0.5s ease; 
}

.services .icon i:hover {
	color:#fff;
}

.services h3 {
	font-weight:700;
	font-size:16px;
	text-align:center;
    letter-spacing:1px;
	word-wrap:break-word;
	text-transform:uppercase;
	font-family:"Open Sans", sans-serif;
}

.services p {
	text-align:center;
	font-size:14px;
	word-spacing:1px;
	line-height:1.5em;
	padding-top:5px;
	margin:0;
	color:#8c9398;
}

.services .icon i:after {
	pointer-events:none;
	position:absolute;
	width:100%;
	height:100%;
	border-radius:50%;
	content:'';
	box-sizing:content-box;
}

.services .icon i:after {
	display:none;
}

.services .icon i:before {
	display:block;
	speak:none;
	width:140px; 
	height:140px;  
	line-height:140px; 
	font-size:60px;
}

.services .icon i:hover:before {
	animation:topbottom 0.3s forwards;
}

@keyframes topbottom {
 	49% {
 		transform:translateY(-100%);
	}
	
 	50% {
 		opacity:0;
 		transform:translateY(100%);
	}
	
 	51% {
 		opacity:1;
	}
}

/***************************
    - 9. Contact info -
***************************/
.contact-info {
	padding:80px 0;
	z-index:10;
	color:#fff;
	background-repeat:no-repeat;
	background-position:center center;
	background-attachment:fixed;
	background-size:cover;
}

.large-info {
	font-family:"Open Sans", sans-serif;
	font-size:40px;
	line-height:1;
	padding:20px 25px;
	background-color:rgba(255, 255, 255, 0.1);
	border-radius:3px;
	display:inline-block;
	color:#fff !important;
	font-weight:500;
}

.large-info i {
	padding-right:10px;
}

.contact-icon {
	margin:10px 0;
	font-size:20px;
	line-height:1;
}

a.contact-link,
p.contact-address {
	color:rgba(255, 255, 255, 0.7);
	text-decoration:none !important;
	transition:all 0.5s ease;	
}

p.contact-address {
	margin-bottom:0;	
}

.offsetTopS {
    padding-top:20px;
}

/***************************
    - 10. Contact form -
***************************/
.contact {
	background-color:#fff;
	padding:80px 0;
	z-index:10;
}

.contact input[type='text'], .contact textarea {
	width:100%;
	background:#fff;
	border:1px solid #ddd;	
	padding:14px 18px;
	margin-bottom:30px;
	font-size:14px;
	line-height:1;
	outline:none;
	border-radius:3px;
    transition:all 0.3s !important;
}

.contact textarea {
	height:207px;
}

.contact input[type='submit'] {
	display:block;
	color:#fff; 
	width:12%;
	height:54px;
	margin:20px auto 0;
	word-spacing:1px;
	outline:none;
	font-family:'Open Sans', sans-serif;
	font-size:14px;
	font-weight:700;
	border:0;
	cursor:pointer;
	border-radius:3px;
    transition:all 0.3s ease-in-out !important;
}

.contact .error {
	position:relative;	
}

.contact .error .name,
.contact .error .email {
    position:absolute;
	display:inline-block;
	top:-6px;
	right:19px;
    padding-left:9px;
	text-align:right;
}

.contact .error .message {
   	position:absolute;
	display:inline-block;
   	right:0;
    bottom:110px;
	margin-right:20px;
    padding-left:9px;
	text-align:right;
}

.contact .notification_ok,
.contact .notification_error {
  	position:absolute;
	top:-36px;
	width:96%;
	text-align:center;
  	color:#3d4a6e;
	margin-top:5px;
  	margin-bottom:10px;
	font-weight:500;
  	font-size:14px;	
}

.contact .notification_ok i,
.contact .notification_error i {
	padding-right:5px;
}

/**************************
    - 11. Google maps -
**************************/
#google-container {
  	position:relative;
  	width:100%;
  	height:450px;
 	background-color:#e7eaf0;
}

.google-map {
  	position:relative;
}

#zoom-in, #zoom-out {
  	height:32px;
  	width:32px;
  	cursor:pointer;
  	margin-left:40px;
  	background-repeat:no-repeat;
  	background-size:32px 64px;
  	background-image:url("../images/map-controller.svg");
  	transition:all 0.5s ease;
}

#zoom-in {
  	background-position:50% 0;
  	margin-top:100px;
  	margin-bottom:1px;
}

#zoom-out {
  	background-position:50% -32px;
}

/*********************
    - 12. Footer -
*********************/
footer {
	position:relative;
	z-index:10;
	background-color:#242830;
	padding:40px 0;
	color:rgba(237, 237, 237, 0.4);
	text-align:center;
}

/* Copyright */
footer .copyright {
	clear:both;
	line-height:1.5em;
}

footer .copyright > a {
	font-weight:bold;
}

footer a {
	text-decoration:none;
	transition:all 0.5s ease;	
}

footer a:hover {
	color:#fff;
	text-decoration:none;
}

/* Social links */
footer .social-icon {
	clear:both;
	margin-top:20px;	
}

footer .social-icon a {
	display:inline-block;
	margin-right:20px;
	list-style:none;
}

footer .social-icon a:last-child {
	margin-right:0;
}

footer .social-icon a i {
	font-size:16px;
	line-height:16px;
	color:rgba(237, 237, 237, 0.4);
	transition:all 0.5s ease;
}

footer .social-icon a:hover i {
	color:rgba(237, 237, 237, 1);
}

/* Up button */
.up-btn {
	position:absolute;
	display:block;
	left:0;
	right:0;
	top:-26px;
	width:50px;
	height:50px;
	margin:0 auto;
	border-radius:50%;
	color:#fff;
	font-size:18px;
	line-height:46px;
	text-align:center;
}

.up-btn:hover {
	color:#fff;
}

.up-btn i {
	color:#fff;
}