/* ----- Specification ----- */

body {
	font-family: 'Montserrat', sans-serif;
	color: #000;
}

h1 {
	font-size: 64px;
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.04em;
}

h2 {
	font-size: 40px;
}

h3 {
	font-size: 29px;
	font-weight: 700;
}

h4 {
	font-size: 26px;
}

ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

a:hover {
	text-decoration: none;
}

p {
	font-size: 16px;
	line-height: 1.5em;
	margin-bottom: 1em;
}

button:focus {
	outline: none;
}

a,button,
.offer__icon {
	transition: all 0.5s ease;
}

.btn {
	display: block;
	color: #fff;
	border: none;
}

.btn:focus {
	box-shadow: none;
}

/* Preloader start */

#page-preloader {
	position: fixed;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	background: #393c40;
	z-index: 100500;
}

.cssload-loader {
	width: 244px;
	height: 49px;
	line-height: 49px;
	text-align: center;
	position: absolute;
	top: 50%;
	margin-top: -24px;
	left: 50%;
	transform: translate(-50%, -50%);
		-o-transform: translate(-50%, -50%);
		-ms-transform: translate(-50%, -50%);
		-webkit-transform: translate(-50%, -50%);
		-moz-transform: translate(-50%, -50%);
	font-family: helvetica, arial, sans-serif;
	font-weight: 900;
	font-size: 20px;
	color: rgb(106,195,103);
	letter-spacing: 0.2em;
}
.cssload-loader::before, .cssload-loader::after {
	content: "";
	display: block;
	width: 15px;
	height: 15px;
	background: rgb(106,195,103);
	position: absolute;
	animation: cssload-load 0.81s infinite alternate ease-in-out;
		-o-animation: cssload-load 0.81s infinite alternate ease-in-out;
		-ms-animation: cssload-load 0.81s infinite alternate ease-in-out;
		-webkit-animation: cssload-load 0.81s infinite alternate ease-in-out;
		-moz-animation: cssload-load 0.81s infinite alternate ease-in-out;
}
.cssload-loader::before {
	top: 0;
}
.cssload-loader::after {
	bottom: 0;
}

@keyframes cssload-load {
	0% {
		left: 0;
		height: 29px;
		width: 15px;
	}
	50% {
		height: 8px;
		width: 39px;
	}
	100% {
		left: 229px;
		height: 29px;
		width: 15px;
	}
}

@-o-keyframes cssload-load {
	0% {
		left: 0;
		height: 29px;
		width: 15px;
	}
	50% {
		height: 8px;
		width: 39px;
	}
	100% {
		left: 229px;
		height: 29px;
		width: 15px;
	}
}

@-ms-keyframes cssload-load {
	0% {
		left: 0;
		height: 29px;
		width: 15px;
	}
	50% {
		height: 8px;
		width: 39px;
	}
	100% {
		left: 229px;
		height: 29px;
		width: 15px;
	}
}

@-webkit-keyframes cssload-load {
	0% {
		left: 0;
		height: 29px;
		width: 15px;
	}
	50% {
		height: 8px;
		width: 39px;
	}
	100% {
		left: 229px;
		height: 29px;
		width: 15px;
	}
}

@-moz-keyframes cssload-load {
	0% {
		left: 0;
		height: 29px;
		width: 15px;
	}
	50% {
		height: 8px;
		width: 39px;
	}
	100% {
		left: 229px;
		height: 29px;
		width: 15px;
	}
}

/* Preloader finish */

/* Header */

.header {
	height: 100vh;
	padding-top: 6vh;
	background: url('../img/bg-header.jpg')no-repeat center center;
}

.logo:before {
	content: "";
	display: inline-block;
	width: 30px;
	height: 30px;
	margin-right: 2px;
	margin-bottom: -7px;
	border-radius: 50%;
}

.logo_header:before {
	background: rgba(106,195,103,0.85);
}

.logo__link {
	font-size: 42px;
	color: #fff;
	line-height: 0;
	letter-spacing: 0.273em;
}

.logo__link:hover {
	color: #fff;
}

.logo__link span {
	font-size: 9px;
	text-transform: uppercase;
	font-weight: 700;
	letter-spacing: 0.3em;
	margin-left: 41px;
	margin-top: 5px;
	display: block;
}

.nav__link {
	font-size: 17px;
	color: #fff;
	padding: 3px 16px 4px;
	border-radius: 5px;
}

.nav__link:hover {
	color: #fff;
	background: rgba(106,195,103,0.7);
}

.btn__call {
	border-radius: 5px;
	margin-left: auto;
	padding: 6px 15px;
}

.btn__call_header {
	background: rgba(106,195,103,0.67);
}

.btn__call i {
	color: #fff;
	margin-right: 5px;
	transform: rotate(90deg);
}

.btn__call:hover {
	box-shadow: 0 0 10px #e4ece9;
}

.btn__call:active {
	box-shadow: 0 0 10px #789a8c inset;
}

.offer {
	margin-top: 28vh;
}

.offer__text {
	color: #fff;
	font-size: 26px;
	margin-left: 2px;
}

.offer__icons-border {
	width: 172px;
	height: 50px;
	margin-top: 40px;
	background: rgba(255,255,255,0.6);
	border-radius: 10px;
	position: relative;
}

.offer__icons {
	width: 166px;
	padding: 8px 10px;
	background: rgba(255,255,255,0.7);
	border-radius: 8px;
	justify-content: space-around;
	position: absolute;
	top: 3px;
	right: 3px;
}

.offer__icon {
	font-size: 16.67px;
	width: 28px;
	height: 28px;
	justify-content: center;
	align-items: center;
}

.offer__icon_fb {
	color: #3d6ca8;
	border: 2px solid #3d6ca8;
}

.offer__icon_tw {
	color: #43c9fd;
	border: 2px solid #43c9fd;
}

.offer__icon_tg {
	color: #25a3d4;
	border: 2px solid #25a3d4;
}

.offer__icon_fb:hover {
	background: #3d6ca8;
	color: #fff;
}

.offer__icon_tw:hover {
	background: #43c9fd;
	color: #fff;
}

.offer__icon_tg:hover {
	background: #25a3d4;
	color: #fff;
}

.down {
	width: 55px;
	height: 55px;
	border: 4px solid #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto;
	margin-top: 10vh;
}

.down i {
	font-size: 26px;
	color: #fff;
}

.down:hover {
	transform: translateY(7px);
}

/* Servises */

.entertainment {
	padding: 40px 0;
}

.entertainment__title {
	text-align: center;
	margin-bottom: 50px;
}

.service {
	text-align: center;
}

.service__circle {
	width: 200px;
	height: 200px;
	margin: 0 auto;
	background: grey;
	border-radius: 50%;
}

.service__circle_fishing {
	background: url(../img/fishing.jpg)no-repeat center center / cover;
}

.service__circle_canoes {
	background: url(../img/canoes.jpg)no-repeat center center / cover;
}

.service__circle_horses {
	background: url(../img/horses.jpg)no-repeat center center / cover;
}

.service__title {
	margin: 22px 0;
}

.btn__more {
	text-align: center;
	padding: 8px 25px;
	margin: 0 auto;
	border-radius: 50px;
	font-size: 19px;
	margin-top: 35px;
	background: rgb(106,195,103);
}

.btn__more:hover {
	box-shadow: 0 0 8px #636d69;
	color: #fff;
}

.btn__more:active {
	box-shadow: 0 0 8px #789a8c inset;
}

/* Details-fishing */

.details-fishing {
	color: #fff;
	background: #1f5f33;
}

.details-fishing__img {
	height: 100%;
	background: url(../img/fishing-house.jpg)no-repeat;
	background-position: center;
}

.details-fishing__title,
.details-canoes__title,
.details-horses__title,
.restaurant__title {
	margin-bottom: 25px;
}

.details-fishing__item:before,
.details-canoes__item:before,
.details-horses__item:before {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	margin-bottom: 3px;
	margin-right: 5px;
	border-radius: 50%;
	background: #fff;
}

.details-fishing__item,
.details-canoes__item,
.details-horses__item,
.restaurant__item {
	font-size: 18px;
	margin-left: 10px;
	margin-bottom: 10px;
}

/* Details-canoes*/

.details-canoes {
	color: #fff;
	background: #b5320b;
}

.details-canoes__img {
	height: 100%;
	background: url(../img/canoes-group.jpg)no-repeat;
	background-position: center;
}

.details-fishing__info,
.details-canoes__info,
.details-horses__info {
	padding: 35px 0 35px 100px;
}

/* Details-horses*/

.details-horses {
	color: #fff;
	background: #b1971a;
}

.details-horses__img {
	height: 100%;
	background: url(../img/horses-love.jpg)no-repeat;
	background-position: center top;
	background-size: 560px;
}

/*Restaurant*/

.restaurant {
	padding: 50px 0;
}

.restaurant__circle {
	width: 323px;
	height: 323px;
	border-radius: 50%;
	background: url(../img/restaurant.jpg)no-repeat;
}

.restaurant__item:before {
	content: "";
	display: inline-block;
	width: 6px;
	height: 6px;
	margin-bottom: 3px;
	margin-right: 5px;
	border-radius: 50%;
	background: #000;
}

/*Footer*/

.footer {
	padding: 36px 0;
	background: #345980;
}

.logo_footer:before {
	background: rgb(106,195,103);
}

.copyright__text {
	font-size: 15px;
	color: #fff;
	margin-bottom: 0;
}

.copyright__link {
	margin-left: 25px;
	font-size: 16.67px;
	color: #fff;
	width: 28px;
	height: 28px;
	border: 2px solid #fff;
	justify-content: center;
	align-items: center;
}

.copyright__icon .fa-telegram-plane {
	margin-right: 2px;
}

.copyright__link:hover {
	color: #345980;
	background: #fff;
}

.btn__call_footer {
	background: rgb(106,195,103);
}

/* Menu Hamburger */

.menu-hamburger {
	position: relative;
}

.hamburger{
	background: none;
	position: absolute;
	top: -19px;
	right: 0;
	color: #fff;
	border: 0;
	font-size: 1.7em;
	cursor: pointer;
	outline: none;
	z-index: 1000;
}

.cross {
	background: none;
	position: absolute;
	top: -21px;
	right: 0;
	color: #fff;
	border: 0;
	font-size: 1.9em;
	cursor: pointer;
	outline: none;
	z-index: 1000;
}

.menu-burger { 
	z-index: 1000;
	width: 230px;
	background: rgba(250,250,250,0.9);
	position: absolute;
	top: 25px;
	right: 6px;
	text-align: center;
	border-radius: 0 0 8px 8px;
}

.menu-burger li {
	border-bottom: #8b8b8d 1px solid;
	font-size: 16px;
	color: #505153;
}

.menu-burger a {
	display: block;
	color: #000;
	line-height: 3em;
}

.menu-burger a:focus {
	outline: none;
}

.menu-burger a:hover {
	background: rgb(250,250,250);
}

.menu-burger a:active {
	box-shadow: 0 0 4px #908c8c inset;
}

.btn__call_burger {
	margin: 16px auto;
	background: rgb(106,195,103);
}

.btn__call_burger:hover {
	box-shadow: 0 0 8px #3a403d;
}

.btn__call_burger:active {
	box-shadow: 0 0 10px #789a8c inset;
}

/* Scroll up button */

#toTop {
	width: 60px;
	background: #fff;
	padding: 3px;
	text-align: center;
	position: fixed;
	bottom: 10px;
	right: 10px;
	cursor: pointer;
	display: none;
	color: #345980;
	font-size: 13px;
	border: 1px solid #345980;
	border-radius: 4px;
}

/* ----- Styles ArcticModal ----- */

input {
	border: none;
}

input:invalid {
	box-shadow: none;
}

input:focus {
	outline: none;
}

.box-modal {
	position: relative;
	width: 412px;
	background: #fff;
	color: #3c3c3c;
	font: 14px/18px 'Montserrat', sans-serif;
	border-radius: 6px;
}

.box-modal_close { 
	position: absolute;
	right: 10px; top: 6px;
	font-size: 15px;
	line-height: 15px;
	color: #999; cursor:
	pointer;
}

.box-modal_close:hover {
	color: #666;
}

.arcticmodal-overlay {
	background: #131731!important;
	opacity: 0.93!important;
}

.form-modal {
	padding: 48px 48px 48px 48px;
	margin: 0 auto;
	text-align: center;
	background: #fff;
	border-radius: 6px;
}

.form-modal__title {
	font-family: 'Montserrat', sans-serif;
	font-size: 21px;
	font-weight: 700;
	margin-bottom: 12px;
}

.form-modal__text {
	font-family: 'Montserrat', sans-serif;
	font-size: 14px;
	margin-bottom: 3px;
}

.form-modal input {
	width: 100%;
	font-family: 'Montserrat', sans-serif;
	font-size: 14px;
	color: #404048;
	padding: 28px 0 11px;
	border-bottom: 1px solid #bababa;
}

.form-modal input:focus {
	color: #000;
	padding: 28px 0 11px;
	border-bottom: 1px solid #000;
}

.form-modal-btn {
	width: 100%;
	font-size: 17px;
	margin-top: 27px;
	padding: 8px 0;
	background: rgb(106,195,103);
	border-radius: 5px;
}

.form-modal-btn:hover {
	box-shadow: 0 0 8px #526960;
}

.form-modal-btn:active {
	box-shadow: 0 0 10px #789a8c inset;
}

.form-modal-btn i {
	color: #fff;
	margin-right: 5px;
}

/* ----- Media Queries ----- */

/* 1200px < */

@media screen and (min-width: 1200px) {

	.container {
		max-width: 83%;
	}

	.details-fishing__img {
		background-position: right;
	}

	.details-horses__img {
		background-position: right top;
	}
}

/* 768-992px */

@media screen and (max-width: 991px) {
	
	.service {
		margin-bottom: 55px;
	}

	.btn__more {
		margin-top: 0;
	}

	h3 {
		font-size: 27px;
	}

	.details-fishing__item,
	.details-canoes__item,
	.details-horses__item,
	.restaurant__item {
		margin-left: 0;
		margin-bottom: 5px;
	}

	.details-fishing__info,
	.details-canoes__info,
	.details-horses__info {
		padding-left: 37px;
	}

	.details-fishing__img {
		background-position-x: -186px;
	}

	.details-canoes__img {
		background-position: -142px -122px;
	}

	.details-horses__img {
		background-position-x: -167px;
	}
}

/* 576-768px */

@media screen and (max-width: 767px) {

	h1 {
		font-size: 62px;
	}

	h2 {
		font-size: 35px;
	}

	h3 {
		font-size: 26px;
	}

	h4 {
		font-size: 24px;
	}

	.details-fishing__img {
		height: 280px;
		background-position: left center;
	}

	.details-canoes__img {
		height: 280px;
		background-position: -106px -196px;
	}

	.details-horses__img {
		height: 280px;
		background-position: left top;
	}

	.details-fishing__info,
	.details-canoes__info,
	.details-horses__info {
		padding-left: 60px;
	}

	.restaurant__circle {
		width: 315px;
		height: 315px;
		margin: 0 auto 35px;
	}

	.logo_footer {
		width: 208px;
		margin: 0 auto;
	}

	.copyright__text {
		text-align: center;
		margin-top: 25px;
	}

	.btn__call_footer {
		margin: -54px auto 37px;
	}
}

/* 320-576px */

@media screen and (max-width: 575px) {
	
	h1 {
		font-size: 40px;
	}

	h2 {
		font-size: 30px;
	}

	h3 {
		font-size: 24px;
	}

	h4 {
		font-size: 21px;
	}

	.logo:before {
		width: 20px;
		height: 20px;
		margin-right: 0;
		margin-bottom: -4px;
	}

	.logo__link {
		font-size: 33px;
		letter-spacing: 0.264em;
	}

	.logo__link span {
		font-size: 7px;
		margin-left: 26px;
	}

	.offer {
		margin-top: 14vh;
	}

	.offer__text {
		font-size: 24px;
	}

	.offer__icons-border {
		margin-top: 110px;
	}

	.down {
		margin-top: 7vh;
	}

	.btn__more {
		padding: 6px 20px;
	}

	.details-fishing__info,
	.details-canoes__info,
	.details-horses__info {
		width: 85%;
		padding-left: 0;
		margin: 0 auto;
	}

	.details-fishing__item,
	.details-canoes__item,
	.details-horses__item,
	.restaurant__item {
		font-size: 17px;
	}

	.details-fishing__img {
		height: 240px;
		background-position: -193px center;
	}

	.details-canoes__img {
		height: 240px;
		background-position: -143px -220px;
	}

	.details-horses__img {
		height: 240px;
		background-position: -145px -24px;
	}

	.restaurant__circle {
		width: 250px;
		height: 250px;
	}

	.restaurant__info {
		width: 90%;
		margin: 0 auto;
	}

	.logo_footer  {
		width: 158px;
	}

	.box-modal {
		width: 90%;
		margin: 0 auto;
		padding: 20px 15px;
	}

	.box-modal_close {
		font-size: 12px;
		top: 5px;
		right: 5px;
	}

	.form-modal__title {
		font-size: 16px;
		margin-bottom: 8px;
	}

	.form-modal__text {
		font-size: 13px;
		line-height: 1.4em;
		width: 90%;
		margin: 0 auto;
	}

	.form-modal {
		padding: 0;
	}

	.form-modal input {
		padding: 15px 0 10px;
	}
}
