body {
	font-family: 'DM Sans' !important;
}

@media screen and (min-width: 768px) {
	.with-padding {
		padding: 0 80px !important;
	}
}

.jumbotron {
	background: linear-gradient( rgba(24, 92, 172, 0.5), rgba(24, 92, 172, 0.5) ), url('../imgs/header.jpg');
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	padding: 80px 15px 50px;
	border-radius: 16px;
	text-align:center;
	color:white;
	position: relative;
}

.jumbotron.search-block {
	background-image: none;
	background-color: #F1F6F9;
	padding: 40px 15px 20px;
}

.jumbotron.search-block h1,
.jumbotron.search-block h2 {
	color: black;
}

.jumbotron h1 {
	font-weight:700;
	font-size: 48px;
	line-height: 62.5px;
}

.jumbotron h1 a {
	color:white;
	text-decoration:none;
}

.jumbotron h2 {
	font-weight: 400;
	font-size: 18px;
	line-height: 23.44px;
}

button.add-place {
	position: absolute;
	right: 90px;
	padding: 14px;
	border-radius: 16px;
	background-color: white;
	border: none;
	top: calc( 50% - 14px );
}

button.add-place a {
	text-decoration: none;
	color: black;
}

.search .form-group {
	position: relative;
}

.search .form-group::before {
	content: " ";
	position: absolute;
	width: 24px;
	height: 24px;
	background-image: url( '../imgs/location-marker.png' );
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	left: 27px;
	top: 24px;
}

.search input {
	border-radius:64px;
	padding: 23px 57px;
	font-size: 18px;
	line-height: 23.44px;
	color: black;
	text-align:left;
	border: none;
}

@media screen and (max-width: 767px) {
	.jumbotron {
		padding: 50px 15px 25px 15px;
	}

	.jumbotron h1 {
		font-size: 36px;
		line-height: 42.5px;
	}

	.search {
		margin: 17px auto 15px auto;
	}
}

nav.navbar {
	background-color:white !important;
	padding: 45px 20px 28px;
	font-weight:600;
	border-radius:8px;
}

nav.navbar .navbar-brand {
	color:black;
	font-weight:400;
	font-size: 20px;
}

@media screen and (min-width: 1024px) {
	nav.navbar .navbar-brand {
		margin-right:30px;
	}
}

nav.navbar img {
	margin-right:5px;
}
nav.navbar a {
	color:#424F78;
	font-weight:500;
}

nav.navbar .active a {
	font-weight:700;
	color:black;
}

nav.navbar a.nav-link {
	padding: 13px 10px !important;
}

nav.navbar a.cta-button {
	background-color: #424F78;
	color: white;
	border-radius: 8px;
	padding: 13px 22px !important;
}

.navbar-toggler {
	border-radius: 16px !important;
	border: 1px solid #424F78 !important;
	background-color: #424F78 !important;
}

.navbar-toggler:focus {
	box-shadow: none !important;
}

.navbar-toggler[aria-expanded="false"] .navbar-toggler-icon {
	background-image: url( '../imgs/navbar-toggler.svg' );
	background-size: 69%;
}

.navbar-toggler[aria-expanded="true"] .navbar-toggler-icon {
	background-image: url( '../imgs/navbar-toggler-close.svg' );
	background-size: 69%;
}

table th {
	font-weight: 600;
	padding: 10px 15px 10px 0 !important;
}

table td {
	padding: 10px 0 !important;
}

table td a {
	color:black;
	word-break: break-word;
}

.block {
	background-color: white;
	border-radius: 16px;
	margin: 0 0 25px;
	padding: 43px 48px;
	position: relative;
}

.block a.btn.suggest-edit {
	display: none;
}

@media screen and (max-width: 991px) {
	.block {
		padding: 20px;
		margin: 35px -20px 25px;
	}

	.gg-container {
		margin: -14px -20px 25px;
	}
}

.block a.btn.suggest-edit {
	display: block;
	position: absolute;
	top: -40px;
	right: 0;
	background-color: transparent;
	border: 0px;
	color: black;
	font-size: 14px;
	font-weight: 700;
	line-height: 18.23px;
}

.block a.btn.suggest-edit br {
	display: none;
}

@media screen and (min-width: 1200px) {
	.block a.btn.suggest-edit {
		display: block;
		position: absolute;
		top: 15px;
		right: 15px;
		background-color: white;
		border: 0px;
		color: black;
		font-size: 14px;
		font-weight: 700;
		line-height: 18.23px;
	}

	.block a.btn.suggest-edit br {
		display: block;
	}
}

.block.cta {
	background-color: #FCE3A6;
	background-image: url('../imgs/app.png');
	background-position: bottom;
	background-repeat: no-repeat;
	background-size: 143px 177px;
	padding-bottom: 200px;
}

.block.cta h4 {
	font-size: 24px;
	font-weight: 700;
	height: 36px;
}

.block.cta .content p {
	line-height: 20.83px;
}

@media screen and (min-width:1024px) {
	.block.cta {
		background-position: calc(100% - 25px) bottom;
		padding-bottom: 20px;
	}

	.block.cta .content {
		padding-right: 180px;
	}
}

.block.cta a {
	background-color:black;
	border-color:black;
	font-size:16px;
	font-weight:600;
}

.block h3 {
	font-size:22px;
	font-weight:600;
}

.content {
	padding: 5px 0;
}

.content.contact a {
	color: black;
}

.content.contact a:hover {
	color: var(--bs-link-hover-color);
}

a.link {
	display: block;
	color: black;
	margin: 10px 0;
	padding: 8px 0;
	font-size: 20px;
	border-radius: 8px;
	font-weight: 400;
	line-height: 26px;
	text-decoration: none;
}

a.link .thumbnail {
	height: 264px;
	margin-bottom: 8px
}

a.link .thumbnail img {
	width: 100%;
    height: 100%;
    object-fit: cover;
    overflow: hidden;
	border-radius: 16px;
}

a.link .reviews {
	color: #707070;
}

a.link .reviews span {
	font-size: 15px;
}

a.link .reviews .score {
	vertical-align: middle;
	margin-left: 10px;
}

a.link p {
	margin-bottom: 0px;
}

a.link span.city {
	font-size: 16px;
	color: #707070;
}

.carousel-inner {
	margin:	0 0 25px 0;
	border-radius: 8px;
}

.carousel-inner .carousel-item {
	height: 200px;
}

@media screen and (min-width: 1024px) {
	.carousel-inner .carousel-item {
		height: 400px;
	}
}

@media screen and (min-width: 1200px) {
	.carousel-inner .carousel-item {
		height: 600px;
	}
}

.carousel-inner .carousel-item img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

ol.breadcrumb {
	margin-top: 30px;
	margin-bottom: 0 !important;
	display: block;
}

@media screen and (min-width:1024px) {
	ol.breadcrumb {
		margin-left: -11px;
	}
}

.breadcrumb-item {
	padding-left: 0 !important;
}

.breadcrumb-item:not(:first-child):not(:last-child) {
	margin-left: 10px;
}

.breadcrumb-item:not(:last-child) {
	float: left;
	font-size: 18px;
	line-height: 23.44px;
}

.breadcrumb-item:last-child {
	font-size: 28px;
	line-height: 32px;
	color: black !important;
	padding-top: 25px;
	font-weight: 700;
	margin-left: -1px;
}

.breadcrumb a {
	color:black;
	text-decoration:none;
}

.breadcrumb-item::before {
	content: " " !important;
}

.breadcrumb-item:not(:last-child)::after {
	content: ">" !important;
	padding-left: 8px !important;
}

#reviews .count {
	color: black;
	opacity: 0.5;
}

@media screen and (max-width: 1024px) {
	.single-jachthaven {
		padding: 0 15px !important;
	}
}

.single-jachthaven {
	margin-top: 50px !important;
	padding: 50px 80px;
	background-color: #F1F6F9;
	border-radius: 16px;
}

.single-jachthaven h1 {
	font-size: 32px;
	font-weight: 700;
	line-height: 41.66px;
	margin-bottom: 15px;
}

.single-jachthaven h2 {
	font-size: 24px;
	font-weight: 700;
	line-height: 31.25px;
	margin-bottom: 13px;
}

.pagination {
	display: flex;
justify-content: center;
}

.pagination a, .pagination span {
	color: black;
	text-decoration: none;
	font-size: 18px;
	line-height: 23.44px;
	padding: 13px 21px;
}

.pagination a:hover {
	color: #1B3C5F;
}

.pagination a.active {
	color: white;
	text-decoration: none;
	padding: 13px 21px;
	background-color: #1B3C5F;
	border-radius: 16px;
}

footer {
	background-color: #1B3C5F;
	border-top-left-radius: 16px;
	border-top-right-radius: 16px;
	color: white;
	margin-top: 100px;
	padding: 62px 82px;
}

footer h2 {
	font-weight: 400;
	font-size: 22px;
	line-height: 28.64px;
}

footer h3 {
	font-size: 14px;
	opacity: 0.5;
	line-height: 18.23px;
}

footer ol {
	list-style-type: none;
	padding-left: 0;
}

footer ol a {
	color: white;
	text-decoration: none;
	font-size: 15px;
	line-height: 30px;
}

footer ol a:hover {
	color: white;
}

div.facilities {
	display: flex;
	line-height: 30px;
	font-weight: 500;
	font-size: 16px;
	color: #707070;
	margin-top: 5px;
}

span.icon {
	display: block;
	width: 30px;
	height: 30px;
	background-color: #F1F6F9;
	background-repeat: no-repeat;
	background-position: center;
	border-radius: 15px;
	margin-right: 5px;
}

span.icon:not(:first-child){
	margin-left: 8px;
}

span.icon.wifi {
	background-image: url( '../icons/wifi.png' );
	background-size: 17.5px 12.5px;
}

span.icon.electricity {
	background-image: url( '../icons/electricity.png' );
	background-size: 14px 18.67px;
}

span.icon.dayrate {
	background-image: url( '../icons/dayrate.svg' );
	background-size: 10px;
}

span.icon.nightrate {
	background-image: url( '../icons/nightrate.svg' );
	background-size: 17.5px;
}

.app-banner {
	background-color: #28B797;
	height: 80px;
	padding: 19px 16px;
	position: relative;
}

.app-banner img.icon {
	width: 100%;
	max-height: 42px;
	max-width: 42px;
	float: left;
}

.app-banner img.close {
	position: absolute;
	right: 8px;
	top: 8px;
	height: 12px;
	width: 12px;
}

.app-banner .text {
	padding-left: 14px;
	display: flex;
	flex-direction: column;
	align-content: center;
}

.app-banner .text p {
	font-weight: 700;
	color: white;
	margin-bottom: 0;
}

.app-banner .text p:nth-child(1) {
	font-size: 14px;
	line-height: 18.23px;
}

.app-banner .text p:nth-child(2) {
	font-size: 16px;
	line-height: 20.83px;
}

.app-banner button.download-button {
	background-color: white;
	padding: 11px 14px;
	border: none;
	border-radius: 16px;
	font-size: 12px;
	font-weight: 700;
	line-height: 15.62px;
	height: 100%;
	float: right;
}

.app-banner button.download-button a {
	text-decoration: none;
	color: #424F78;

}

@media screen and (min-width: 991px) {
	.homepage-blocks {
		padding: 0 86px !important;
	}
}

.homepage-blocks h2 {
	text-align: center;
}

.homepage-blocks h3 {
	font-weight: 700;
	font-size: 32px	;
	line-height: 36px;
}

.homepage-blocks h4 {
	font-size: 24px;
	line-height: 36px;
	font-weight: 700;
}

.homepage-blocks p {
	font-weight: 400;
	font-size: 16px;
	line-height: 20.83px;
}

@media screen and (min-width:768px) {
	.homepage-blocks .row {
		height: 100%;
	}
}

.homepage-blocks .single-block {
	padding: 5px;
}

.homepage-blocks .single-block .content {
	padding: 25px 23px;
	border-radius: 21px;
	position: relative;
	padding-bottom: 80px;
}

@media screen and (min-width:768px) {
	.homepage-blocks .single-block .content {
		height: 100%;
	}
}

.homepage-blocks .single-block .content.green {
	background-color: #DBFFE1;
	padding-bottom: 287px;
}

.homepage-blocks .single-block .content.green img {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
}

.homepage-blocks .single-block .content.blue {
	background-color: #CCF2F8;
}

.homepage-blocks .single-block .content.blue img,
.homepage-blocks .single-block .content.grey img {
	width: 64px;
	height: 64px;
	position: absolute;
	bottom: 20px;
	right: 20px;
}

.homepage-blocks .single-block .content.grey {
	background-color: #F1F6F9;
}

.homepage-blocks .single-block .content.yellow {
	background-color: #FCE3A6;
	padding-bottom: 193px;
}

.homepage-blocks .single-block .content.yellow img {
	width: 143px;
	height: 177px;
	position: absolute;
	margin-left: calc( -143px / 2 );
	left: 50%;
	bottom: 0;
}

@media screen and ( min-width: 1024px ) {
	.homepage-blocks .single-block .content.yellow {
		padding: 25px 184px 25px 25px;
	}

	.homepage-blocks .single-block .content.yellow img {
		right: 33px;
		left: auto;
		margin-left: 0;
	}
}


.bottom-copy h2 {
	font-weight: 700;
	font-size: 32px;
	line-height: 41.66px;
}

.bottom-copy p {
	font-size: 16px;
	line-height: 28px;
}

.bottom-copy .col {
	margin: 10px 0;
}

.bottom-copy .col .content {
	background-color: #F6F6F6;
	padding: 35px;
	border-radius: 16px;
	height: 100%;
}

.jachthaven-overview h2, .homepage-blocks h2 {
	text-align: center;
	margin-bottom: 32px;
	margin-top: 100px !important;
	margin-bottom:  !important;
	font-size: 32px;
	font-weight: 700;
	line-height: 41.66px;
}

.rate-review a {
	text-decoration: none;
}

.rate-review a img.empty-star {
	width: 22px;
	height: 22px;
}

@media screen and ( min-width: 768px ) {
	.rate-review a img.empty-star {
		width: 27px;
		height: 27px;
	}
}

.related-marinas {
	margin-top: 50px !important;
}

@media screen and ( min-width: 768px ) {
	.related-marinas {
		margin-top: 63px !important;
	}
}

.related-marinas h3 {
	text-align: center;
}

.search-bar {
	background-color: #F1F6F9;
	padding: 30px 90px 40px;
	border-radius: 16px;
}

.search-bar .search-block {
	margin-top: 15px;
}

a.add-marina {
	text-decoration: none;
	color: black;
}

a.add-marina button {
	margin-top: 23px;
	background-color: white;
	border-radius: 16px;
	border: none;
	padding: 14px;
	float: right;
	margin-right: -11px;
}

@media screen and (max-width: 1024px) {
	.search-bar {
		padding: 25px 18px;
	}

	a.add-marina button {
		background-color: transparent;
		padding: 0;
		margin-top: 35px;
	}

	.search .form-group {
		margin-top: 13px;
	}
}

.categories {
	margin-top: 46px !important;
}

.categories a {
	color: white;
	text-decoration: none;
}

.categories a:hover {
	color: white;
}

.categories .category {
	border-radius: 8px;
	background-color: #808CB2;
	padding: 11px 12px;
	display: inline-block;
	margin-bottom: 4px;
	font-size: 15px;
	line-height: 19.53px;
}

.categories span#show-all {
	margin-left: 16px;
	font-size: 15px;
	line-height: 19.53px;
	color: #808CB2;
	font-weight: 500;
}

.categories span#show-all:hover {
	cursor: pointer;
}

.distance span {
	font-size: 15px;
	color: #707070;
}

div#livesearch-results {
	position: absolute;
	width: 100%;
	padding: 29px 32px;
	top: 80px;
	background-color: white;
	display: none;
	border-radius: 35px;
	-webkit-box-shadow: 0px 10px 16px rgba(0, 0, 0, 0.1);
    box-shadow: 0px 10px 16px rgba(0, 0, 0, 0.1);
	z-index: 9999;
	text-align: left;
}

div#livesearch-results ul {
	list-style-type: none;
	padding: 0;
	margin: 0;
}

#livesearch-results ul li {
	padding: 0;
}

#livesearch-results ul li:hover {
	background-color: #F1F6F9;
	border-radius: 16px;
}

#livesearch-results ul li a {
	display: block;
	padding: 12px 25px;
	color: black;
	text-decoration: none;
	font-size: 18px;
}

#livesearch-results ul li:hover a {
	padding: 16px 25px;
	margin: -4px 0;
}

.advanced-search {
	margin-top: 36px !important;
	background-color: #F1F6F9;
	padding-top: 40px !important;
	padding-bottom: 68px !important;
	padding: 40px 80px 68px;
	border-radius: 16px;
}

.advanced-search #open {
	color: #707070;
	text-decoration: underline;
}	

.advanced-search .title {
	font-size: 24px;
	line-height: 31.25px;
	font-weight: 700;
	margin-bottom: 13px;
}

.advanced-search .options {
	margin-top: 13px;
}

.advanced-search .options .filters {
	background-color: white;
	border-radius: 16px;
	padding: 24px 36px;
	height: 100%;
}

.advanced-search .options .filters .number-filter {
	padding: 16px 0;
	border-bottom: 1px solid #EFEFF4;
}

.advanced-search .options .filters .number-filter label {
	padding: 9px 0;
}

.advanced-search .options .filters .number-filter span {
	color: #707070;
	font-size: 12px;
	line-height: 15.62px;
}


.advanced-search .options .filters .number-filter input[type='number'] {
	border: none;
	background-color: #F1F6F9;
	padding: 10px 12px;
	margin: 0 4px;
	max-width: 70px;
	border-radius: 8px;
	font-size: 15px;
}

/* CSS checkbox */
.advanced-search .options .filters .checkbox-filter input[type='checkbox'] { 
	position: absolute; 
	overflow: hidden; 
	clip: rect(0 0 0 0); 
	height: 1px; 
	width: 1px; 
	margin: -1px; 
	padding: 0; 
	border: 0; 
}

.advanced-search .options .filters .checkbox-filter input[type='checkbox'] + label {
	position: relative; 
	font-size: 15px; 
	line-height: 19.53px;
	cursor: pointer; 
	display: inline-flex; 
	align-items: center; 
	color: rgb(0, 0, 0);
	margin: 14px 0 14px 30px;
}

.advanced-search .options .filters .checkbox-filter input[type='checkbox'] + label::before { 
	content: " "; 
	display: inline-block; 
	vertical-align: middle; 
	margin-right: 8px;
	width: 24px; 
	height: 24px;
	background-color: rgb(241, 246, 249); 
	border-width: 1px; 
	border-style: solid; 
	border-color: rgb(241, 246, 249); 
	border-radius: 6px; box-shadow: none;
	position: absolute;
	left: -30px;
	top: -3px;
}

.advanced-search .options .filters .checkbox-filter input[type='checkbox']:checked + label::after { 
	content: " "; 
	background-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCA1MTIgNTEyIj48cGF0aCBmaWxsPSIjMDAwMDAwIiBkPSJNMTczLjg5OCA0MzkuNDA0bC0xNjYuNC0xNjYuNGMtOS45OTctOS45OTctOS45OTctMjYuMjA2IDAtMzYuMjA0bDM2LjIwMy0zNi4yMDRjOS45OTctOS45OTggMjYuMjA3LTkuOTk4IDM2LjIwNCAwTDE5MiAzMTIuNjkgNDMyLjA5NSA3Mi41OTZjOS45OTctOS45OTcgMjYuMjA3LTkuOTk3IDM2LjIwNCAwbDM2LjIwMyAzNi4yMDRjOS45OTcgOS45OTcgOS45OTcgMjYuMjA2IDAgMzYuMjA0bC0yOTQuNCAyOTQuNDAxYy05Ljk5OCA5Ljk5Ny0yNi4yMDcgOS45OTctMzYuMjA0LS4wMDF6Ii8+PC9zdmc+"); 
	background-repeat: no-repeat; 
	background-size: 15px 15px; 
	background-position: center center; 
	position: absolute; 
	display: flex; 
	justify-content: center; 
	align-items: center; 
	margin-left: 0px; 
	left: -30px; 
	top: -3px;
	text-align: center; 
	background-color: transparent; 
	font-size: 10px; 
	height: 25px; 
	width: 25px; 
}
/* CSS checkbox end */

.advanced-search input[type='submit'] {
	background-color: #424F78;
	border: none;
	color: white;
	border-radius: 8px;
	padding: 8px 14px;
	margin-top: 8px;
}

a.advanced-search-link {
	color: #707070;
}

a.advanced-search-link:hover {
	color: black;
}

@media screen and (max-width: 1024px){
	.advanced-search {
		padding: 25px 18px !important;
	}
}

.error-404 {
	background-color: #F1F6F9;
	padding-top: 134px !important;
	padding-bottom: 93px !important;
	border-radius: 16px;
}

.error-404 h1,
.error-404 h2,
.error-404 h3,
.error-404 p {
	text-align: center;
	font-family: 'DM Sans' !important;
}

.error-404 .message h1 {
	font-size: 48px;
	line-height: 62.5px;
	font-weight: 700;
}

.error-404 .message h2 {
	font-size: 32px;
	line-height: 41.66px;
	font-weight: 700;
}

.error-404 .message p {
	font-size: 18px;
	line-height: 23.44px;
	font-weight: 400;
}

.error-404 .message {
	text-align: center;
}

.error-404 button {
	background-color: #424F78;
	border: none;
	width: auto;
	margin-left: auto;
	margin-right: auto;
	margin-top: 37px;
	padding: 13px 29px;
	border-radius: 16px;
	text-align: center;
}

.error-404 button a {
	color: white;
	text-decoration: none;
	font-size: 18px;
	line-height: 23.44px;
	font-weight: 400;
}

.error-404 .provinces {
	margin-top: 99px;
}

.error-404 .provinces h3 {
	font-size: 18px;
	line-height: 23.44px;
	font-weight: 400;
}

.error-404 .provinces ul {
	list-style-type: none;
	padding: 0;
	text-align: center;
}

.error-404 .provinces ul li a {
	color: #606D99;
	font-size: 15px;
	line-height: 30px;
	text-decoration: none;
}

.search-results {
	margin-top: 52px !important;
}

.detail-bottom-copy {
	background-color: #F6F6F6;
	padding: 35px 35px 47px !important;
	border-radius: 16px;
}

.detail-bottom-copy h3 {
	font-size: 24px;
	line-height: 36px;
	font-weight: 700;
}

.detail-bottom-copy p {
	font-size: 16px;
	line-height: 28px;
}

#detail-images img {
	border-radius: 16px;
}

@media (max-width: 768px){
	.gg-box {
		/* Fix mobile height */
		grid-auto-rows: calc(var(--row-height)) !important;
	}
}

nav.navbar .container {
	max-width: 1300px;
}

@media screen and (min-width: 991px) {
	form.search {
		margin-left: -10px;
	}
}
