/* GOOGLE MAP
================================================================================ */
.map {
	position:relative;
	width:100%;
	height:400px;
	overflow:hidden;
	margin-bottom:2em;
}
.tabbed-module .map {
	margin-bottom:0;
}
.map .googlemap-container {
	width:100%;
	height:100%;
}
.block.gray .map {
	margin-bottom:0;
	padding:6px;
	box-shadow:0 1px 2px 0 rgba(0,0,0,0.2);
	background:#fff;
}
.map img {
	max-width:none;
}
.map > img {
	max-width:100%;
}
.googlemap-container .vcard {
	margin:0;
}
.map button {
	position:absolute;
	top:-2px;
	left:-2px;
	width:100%;
	height:100%;
	overflow:hidden;
	margin:2px;
	padding:2px;
	border-width:0;
	border-style:solid;
	background:transparent;
	text-indent:-100em;
	cursor:pointer;
}
.map a:focus,
.map a:active,
.map button:focus,
.map button:active {
	outline:2px dashed #61bf1a;
}
.map .nav-main .search-residence > *:after {
	display:inline-block;
	width:24px;
	height:24px;
	margin-left:10px;
	background:url(/gui/i/icons/icon-sprite.svg) no-repeat -128px -10px;
	content:"";
	vertical-align:middle;
}


.map-pins {
	clear:both;
	margin:0 0 40px;
}
.map-pins ul {
	width:100%;
}
.map-pins li {
	float:left;
	width:20%;
	list-style:none;
	text-align:center;
}
.map-pins .pin {
	position:relative;
	text-transform:uppercase;
}
.map-pins .pin:before {
	display:inline-block;
	position:relative;
	top:0;
	width:100%;
	height:45px;
	content:"";
	text-align:center;
}
.map-pins .pin-apartment:before {
	background:url(../i/apartment.svg) no-repeat 50% 0;
}
.map-pins .pin-bungalow:before {
	background:url(../i/bungalow.svg) no-repeat 50% 0;
}
.map-pins .pin-cottage:before {
	background:url(../i/cottage.svg) no-repeat 50% 0;
}
.map-pins .pin-farm:before {
	background:url(../i/farm.svg) no-repeat 50% 0;
}
.map-pins .pin-generic:before {
	background:url(../i/generic.svg) no-repeat 50% 0;
}
.map-pins .pin-lot:before {
	background:url(../i/lot.svg) no-repeat 50% 0;
}


.gm-style .gm-style-iw {
	width:358px !important;
}
.gm-style .gm-style-iw .m {
	margin:0;
}
.gm-style .gm-style-iw + div {
	width:24px !important;
	height:24px !important;
	background:#fff;
}
.gm-style .gm-style-iw + div:before {
	display:block;
	position:absolute;
	top:0;
	right:0;
	z-index:10010;
	width:24px;
	height:24px;
	background:red;
	background:#fff url(/gui/i/icons/icon-sprite.svg) no-repeat -7px -10px;
	content:"";
	vertical-align:middle;
}


/* Infobox
----------------------------------------------------------------------------- */
.infoBox > img {
	z-index:1;
	margin-top:5px !important;
	margin-right:5px !important;
}
.map-window {
	position:relative;
	width:300px;
	margin-left:-150px;
	padding:5px 10px;
	box-shadow:0 1px 2px rgba(0,0,0,0.2);
	background:#fff;
	color:#333;
	font-size:15px;
}
.map-window:after {
	display:block;
	position:absolute;
	bottom:-10px;
	left:50%;
	box-sizing:border-box;
	width:10px;
	margin-left:-5px;
	border:5px solid;
	border-color:#fff transparent transparent;
	content:"";
}