/* required styles */

.leaflet-pane,
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-tile-container,
.leaflet-pane > svg,
.leaflet-pane > canvas,
.leaflet-zoom-box,
.leaflet-image-layer,
.leaflet-layer {
	position: absolute;
	left: 0;
	top: 0;
	}
.leaflet-container {
	overflow: hidden;
	}
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow {
	-webkit-user-select: none;
	   -moz-user-select: none;
	        user-select: none;
	  -webkit-user-drag: none;
	}
/* Prevents IE11 from highlighting tiles in blue */
.leaflet-tile::selection {
	background: transparent;
}
/* Safari renders non-retina tile on retina better with this, but Chrome is worse */
.leaflet-safari .leaflet-tile {
	image-rendering: -webkit-optimize-contrast;
	}
/* hack that prevents hw layers "stretching" when loading new tiles */
.leaflet-safari .leaflet-tile-container {
	width: 1600px;
	height: 1600px;
	-webkit-transform-origin: 0 0;
	}
.leaflet-marker-icon,
.leaflet-marker-shadow {
	display: block;
	}
/* .leaflet-container svg: reset svg max-width decleration shipped in Joomla! (joomla.org) 3.x */
/* .leaflet-container img: map is broken in FF if you have max-width: 100% on tiles */
.leaflet-container .leaflet-overlay-pane svg,
.leaflet-container .leaflet-marker-pane img,
.leaflet-container .leaflet-shadow-pane img,
.leaflet-container .leaflet-tile-pane img,
.leaflet-container img.leaflet-image-layer,
.leaflet-container .leaflet-tile {
	max-width: none !important;
	max-height: none !important;
	}

.leaflet-container.leaflet-touch-zoom {
	-ms-touch-action: pan-x pan-y;
	touch-action: pan-x pan-y;
	}
.leaflet-container.leaflet-touch-drag {
	-ms-touch-action: pinch-zoom;
	/* Fallback for FF which doesn't support pinch-zoom */
	touch-action: none;
	touch-action: pinch-zoom;
}
.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom {
	-ms-touch-action: none;
	touch-action: none;
}
.leaflet-container {
	-webkit-tap-highlight-color: transparent;
}
.leaflet-container a {
	-webkit-tap-highlight-color: rgba(51, 181, 229, 0.4);
}
.leaflet-tile {
	filter: inherit;
	visibility: hidden;
	}
.leaflet-tile-loaded {
	visibility: inherit;
	}
.leaflet-zoom-box {
	width: 0;
	height: 0;
	-moz-box-sizing: border-box;
	     box-sizing: border-box;
	z-index: 800;
	}
/* workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=888319 */
.leaflet-overlay-pane svg {
	-moz-user-select: none;
	}

.leaflet-pane         { z-index: 400; }

.leaflet-tile-pane    { z-index: 200; }
.leaflet-overlay-pane { z-index: 400; }
.leaflet-shadow-pane  { z-index: 500; }
.leaflet-marker-pane  { z-index: 600; }
.leaflet-tooltip-pane   { z-index: 650; }
.leaflet-popup-pane   { z-index: 700; }

.leaflet-map-pane canvas { z-index: 100; }
.leaflet-map-pane svg    { z-index: 200; }

.leaflet-vml-shape {
	width: 1px;
	height: 1px;
	}
.lvml {
	behavior: url(#default#VML);
	display: inline-block;
	position: absolute;
	}


/* control positioning */

.leaflet-control {
	position: relative;
	z-index: 800;
	pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
	pointer-events: auto;
	}
.leaflet-top,
.leaflet-bottom {
	position: absolute;
	z-index: 1000;
	pointer-events: none;
	}
.leaflet-top {
	top: 0;
	}
.leaflet-right {
	right: 0;
	}
.leaflet-bottom {
	bottom: 0;
	}
.leaflet-left {
	left: 0;
	}
.leaflet-control {
	float: left;
	clear: both;
	}
.leaflet-right .leaflet-control {
	float: right;
	}
.leaflet-top .leaflet-control {
	margin-top: 10px;
	}
.leaflet-bottom .leaflet-control {
	margin-bottom: 10px;
	}
.leaflet-left .leaflet-control {
	margin-left: 10px;
	}
.leaflet-right .leaflet-control {
	margin-right: 10px;
	}


/* zoom and fade animations */

.leaflet-fade-anim .leaflet-tile {
	will-change: opacity;
	}
.leaflet-fade-anim .leaflet-popup {
	opacity: 0;
	-webkit-transition: opacity 0.2s linear;
	   -moz-transition: opacity 0.2s linear;
	        transition: opacity 0.2s linear;
	}
.leaflet-fade-anim .leaflet-map-pane .leaflet-popup {
	opacity: 1;
	}
.leaflet-zoom-animated {
	-webkit-transform-origin: 0 0;
	    -ms-transform-origin: 0 0;
	        transform-origin: 0 0;
	}
.leaflet-zoom-anim .leaflet-zoom-animated {
	will-change: transform;
	}
.leaflet-zoom-anim .leaflet-zoom-animated {
	-webkit-transition: -webkit-transform 0.25s cubic-bezier(0,0,0.25,1);
	   -moz-transition:    -moz-transform 0.25s cubic-bezier(0,0,0.25,1);
	        transition:         transform 0.25s cubic-bezier(0,0,0.25,1);
	}
.leaflet-zoom-anim .leaflet-tile,
.leaflet-pan-anim .leaflet-tile {
	-webkit-transition: none;
	   -moz-transition: none;
	        transition: none;
	}

.leaflet-zoom-anim .leaflet-zoom-hide {
	visibility: hidden;
	}


/* cursors */

.leaflet-interactive {
	cursor: pointer;
	}
.leaflet-grab {
	cursor: -webkit-grab;
	cursor:    -moz-grab;
	cursor:         grab;
	}
.leaflet-crosshair,
.leaflet-crosshair .leaflet-interactive {
	cursor: crosshair;
	}
.leaflet-popup-pane,
.leaflet-control {
	cursor: auto;
	}
.leaflet-dragging .leaflet-grab,
.leaflet-dragging .leaflet-grab .leaflet-interactive,
.leaflet-dragging .leaflet-marker-draggable {
	cursor: move;
	cursor: -webkit-grabbing;
	cursor:    -moz-grabbing;
	cursor:         grabbing;
	}

/* marker & overlays interactivity */
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-image-layer,
.leaflet-pane > svg path,
.leaflet-tile-container {
	pointer-events: none;
	}

.leaflet-marker-icon.leaflet-interactive,
.leaflet-image-layer.leaflet-interactive,
.leaflet-pane > svg path.leaflet-interactive,
svg.leaflet-image-layer.leaflet-interactive path {
	pointer-events: visiblePainted; /* IE 9-10 doesn't have auto */
	pointer-events: auto;
	}

/* visual tweaks */

.leaflet-container {
	background: #ddd;
	outline: 0;
	}
.leaflet-container a {
	color: #0078A8;
	}
.leaflet-container a.leaflet-active {
	outline: 2px solid orange;
	}
.leaflet-zoom-box {
	border: 2px dotted #38f;
	background: rgba(255,255,255,0.5);
	}


/* general typography */
.leaflet-container {
	font: 12px/1.5 "Helvetica Neue", Arial, Helvetica, sans-serif;
	}


/* general toolbar styles */

.leaflet-bar {
	box-shadow: 0 1px 5px rgba(0,0,0,0.65);
	border-radius: 4px;
	}
.leaflet-bar a,
.leaflet-bar a:hover {
	background-color: #fff;
	border-bottom: 1px solid #ccc;
	width: 26px;
	height: 26px;
	line-height: 26px;
	display: block;
	text-align: center;
	text-decoration: none;
	color: black;
	}
.leaflet-bar a,
.leaflet-control-layers-toggle {
	background-position: 50% 50%;
	background-repeat: no-repeat;
	display: block;
	}
.leaflet-bar a:hover {
	background-color: #f4f4f4;
	}
.leaflet-bar a:first-child {
	border-top-left-radius: 4px;
	border-top-right-radius: 4px;
	}
.leaflet-bar a:last-child {
	border-bottom-left-radius: 4px;
	border-bottom-right-radius: 4px;
	border-bottom: none;
	}
.leaflet-bar a.leaflet-disabled {
	cursor: default;
	background-color: #f4f4f4;
	color: #bbb;
	}

.leaflet-touch .leaflet-bar a {
	width: 30px;
	height: 30px;
	line-height: 30px;
	}
.leaflet-touch .leaflet-bar a:first-child {
	border-top-left-radius: 2px;
	border-top-right-radius: 2px;
	}
.leaflet-touch .leaflet-bar a:last-child {
	border-bottom-left-radius: 2px;
	border-bottom-right-radius: 2px;
	}

/* zoom control */

.leaflet-control-zoom-in,
.leaflet-control-zoom-out {
	font: bold 18px 'Lucida Console', Monaco, monospace;
	text-indent: 1px;
	}

.leaflet-touch .leaflet-control-zoom-in, .leaflet-touch .leaflet-control-zoom-out  {
	font-size: 22px;
	}


/* layers control */

.leaflet-control-layers {
	box-shadow: 0 1px 5px rgba(0,0,0,0.4);
	background: #fff;
	border-radius: 5px;
	}
.leaflet-control-layers-toggle {
	background-image: url(images/layers.png);
	width: 36px;
	height: 36px;
	}
.leaflet-retina .leaflet-control-layers-toggle {
	background-image: url(images/layers-2x.png);
	background-size: 26px 26px;
	}
.leaflet-touch .leaflet-control-layers-toggle {
	width: 44px;
	height: 44px;
	}
.leaflet-control-layers .leaflet-control-layers-list,
.leaflet-control-layers-expanded .leaflet-control-layers-toggle {
	display: none;
	}
.leaflet-control-layers-expanded .leaflet-control-layers-list {
	display: block;
	position: relative;
	}
.leaflet-control-layers-expanded {
	padding: 6px 10px 6px 6px;
	color: #333;
	background: #fff;
	}
.leaflet-control-layers-scrollbar {
	overflow-y: scroll;
	overflow-x: hidden;
	padding-right: 5px;
	}
.leaflet-control-layers-selector {
	margin-top: 2px;
	position: relative;
	top: 1px;
	}
.leaflet-control-layers label {
	display: block;
	}
.leaflet-control-layers-separator {
	height: 0;
	border-top: 1px solid #ddd;
	margin: 5px -10px 5px -6px;
	}

/* Default icon URLs */
.leaflet-default-icon-path {
	background-image: url(images/marker-icon.png);
	}


/* attribution and scale controls */

.leaflet-container .leaflet-control-attribution {
	background: #fff;
	background: rgba(255, 255, 255, 0.7);
	margin: 0;
	}
.leaflet-control-attribution,
.leaflet-control-scale-line {
	padding: 0 5px;
	color: #333;
	}
.leaflet-control-attribution a {
	text-decoration: none;
	}
.leaflet-control-attribution a:hover {
	text-decoration: underline;
	}
.leaflet-container .leaflet-control-attribution,
.leaflet-container .leaflet-control-scale {
	font-size: 11px;
	}
.leaflet-left .leaflet-control-scale {
	margin-left: 5px;
	}
.leaflet-bottom .leaflet-control-scale {
	margin-bottom: 5px;
	}
.leaflet-control-scale-line {
	border: 2px solid #777;
	border-top: none;
	line-height: 1.1;
	padding: 2px 5px 1px;
	font-size: 11px;
	white-space: nowrap;
	overflow: hidden;
	-moz-box-sizing: border-box;
	     box-sizing: border-box;

	background: #fff;
	background: rgba(255, 255, 255, 0.5);
	}
.leaflet-control-scale-line:not(:first-child) {
	border-top: 2px solid #777;
	border-bottom: none;
	margin-top: -2px;
	}
.leaflet-control-scale-line:not(:first-child):not(:last-child) {
	border-bottom: 2px solid #777;
	}

.leaflet-touch .leaflet-control-attribution,
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
	box-shadow: none;
	}
.leaflet-touch .leaflet-control-layers,
.leaflet-touch .leaflet-bar {
	border: 2px solid rgba(0,0,0,0.2);
	background-clip: padding-box;
	}


/* popup */

.leaflet-popup {
	position: absolute;
	text-align: center;
	margin-bottom: 20px;
	}
.leaflet-popup-content-wrapper {
	padding: 1px;
	text-align: left;
	border-radius: 12px;
	}
.leaflet-popup-content {
	margin: 13px 19px;
	line-height: 1.4;
	}
.leaflet-popup-content p {
	margin: 18px 0;
	}
.leaflet-popup-tip-container {
	width: 40px;
	height: 20px;
	position: absolute;
	left: 50%;
	margin-left: -20px;
	overflow: hidden;
	pointer-events: none;
	}
.leaflet-popup-tip {
	width: 17px;
	height: 17px;
	padding: 1px;

	margin: -10px auto 0;

	-webkit-transform: rotate(45deg);
	   -moz-transform: rotate(45deg);
	    -ms-transform: rotate(45deg);
	        transform: rotate(45deg);
	}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
	background: white;
	color: #333;
	box-shadow: 0 3px 14px rgba(0,0,0,0.4);
	}
.leaflet-container a.leaflet-popup-close-button {
	position: absolute;
	top: 0;
	right: 0;
	padding: 4px 4px 0 0;
	border: none;
	text-align: center;
	width: 18px;
	height: 14px;
	font: 16px/14px Tahoma, Verdana, sans-serif;
	color: #c3c3c3;
	text-decoration: none;
	font-weight: bold;
	background: transparent;
	}
.leaflet-container a.leaflet-popup-close-button:hover {
	color: #999;
	}
.leaflet-popup-scrolled {
	overflow: auto;
	border-bottom: 1px solid #ddd;
	border-top: 1px solid #ddd;
	}

.leaflet-oldie .leaflet-popup-content-wrapper {
	-ms-zoom: 1;
	}
.leaflet-oldie .leaflet-popup-tip {
	width: 24px;
	margin: 0 auto;

	-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
	filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
	}
.leaflet-oldie .leaflet-popup-tip-container {
	margin-top: -1px;
	}

.leaflet-oldie .leaflet-control-zoom,
.leaflet-oldie .leaflet-control-layers,
.leaflet-oldie .leaflet-popup-content-wrapper,
.leaflet-oldie .leaflet-popup-tip {
	border: 1px solid #999;
	}


/* div icon */

.leaflet-div-icon {
	background: #fff;
	border: 1px solid #666;
	}


/* Tooltip */
/* Base styles for the element that has a tooltip */
.leaflet-tooltip {
	position: absolute;
	padding: 6px;
	background-color: #fff;
	border: 1px solid #fff;
	border-radius: 3px;
	color: #222;
	white-space: nowrap;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	pointer-events: none;
	box-shadow: 0 1px 3px rgba(0,0,0,0.4);
	}
.leaflet-tooltip.leaflet-clickable {
	cursor: pointer;
	pointer-events: auto;
	}
.leaflet-tooltip-top:before,
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
	position: absolute;
	pointer-events: none;
	border: 6px solid transparent;
	background: transparent;
	content: "";
	}

/* Directions */

.leaflet-tooltip-bottom {
	margin-top: 6px;
}
.leaflet-tooltip-top {
	margin-top: -6px;
}
.leaflet-tooltip-bottom:before,
.leaflet-tooltip-top:before {
	left: 50%;
	margin-left: -6px;
	}
.leaflet-tooltip-top:before {
	bottom: 0;
	margin-bottom: -12px;
	border-top-color: #fff;
	}
.leaflet-tooltip-bottom:before {
	top: 0;
	margin-top: -12px;
	margin-left: -6px;
	border-bottom-color: #fff;
	}
.leaflet-tooltip-left {
	margin-left: -6px;
}
.leaflet-tooltip-right {
	margin-left: 6px;
}
.leaflet-tooltip-left:before,
.leaflet-tooltip-right:before {
	top: 50%;
	margin-top: -6px;
	}
.leaflet-tooltip-left:before {
	right: 0;
	margin-right: -12px;
	border-left-color: #fff;
	}
.leaflet-tooltip-right:before {
	left: 0;
	margin-left: -12px;
	border-right-color: #fff;
	}
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  /* line-height: 1.15; */
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0; }

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
.global-wrap h1 {
  font-size: 2em;
  margin: 0.67em 0 } 
/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent; }

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  text-decoration: underline dotted;
  /* 2 */ }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; }

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline; }

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */ }

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none; }

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none; }

html {
  box-sizing: border-box; }

*, *:before, *:after {
  /*box-sizing: inherit; */}

html {
  font-family: sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%; }

body div.content {
  letter-spacing: normal;
  font-style: normal;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #030303;
  font-size: 0.95rem;
  font-weight: 400;
  font-family: 'Montserrat', sans-serif;
  line-height: 1.45; }

strong {
  font-weight: 700; }

a {
  transition: all, 0.3s ease-in-out;
  text-decoration: none;
  color: #3333FF; }

body {
  margin: 0;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0; }

.app,
#map {
  background: #fff;
  width: 100%;
  min-height: 100vh; }

.app {
  position: relative;
  overflow: hidden; }

#map {
  z-index: 2; }

.leaflet-popup-pane .image-container,
.leaflet-popup .image-container {
  width: 300px;
  min-width: 200px;
  margin-bottom: 0.5rem;
  height: 200px; }

.leaflet-popup-pane img,
.leaflet-popup img {
  object-fit: cover;
  height: 100%;
  width: 100%; }

.leaflet-popup-content .preheader {
  text-transform: uppercase;
  font-size: 0.7rem;
  letter-spacing: 0.04rem; }

.leaflet-popup-content header,
.leaflet-popup-content .header {
  font-size: 0.9rem;
  font-weight: 500;
  padding-bottom: 0.25rem;
  padding-top: 0.5rem;
  display: inline-block; }

.leaflet-popup-content .location {
  display: inline-block;
  padding-top: 0.75rem; }

.leaflet-popup-content > div {
  margin: 1rem 0; }

.leaflet-popup-content > a {
  display: block; }

.app .toolbar {
  transition: all 0.6s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  background: #fff;
  height: 100%;
  position: absolute;
  width: 300px;
  z-index: 100;
  right: -300px;
  top: 0;
  box-shadow: 1px 1px 5px 3px rgba(0, 0, 0, 0.11); }
  .app .toolbar .content {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 0;
    position: absolute;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 999;
    background: #F7F7F7; }
    .app .toolbar .content .type-selector,
    .app .toolbar .content .states-selector {
      font-size: 0.85rem;
      margin-bottom: 1rem; }
    .app .toolbar .content .type-selector .radio:hover {
      background: #f1f1f1;
      border-left-color: #545e69; }
    .app .toolbar .content .type-selector .radio.fp:hover {
      border-left-color: #BE4809; }
    .app .toolbar .content .type-selector .radio.tt:hover {
      border-left-color: #7344AB; }
    .app .toolbar .content .type-selector .radio.qa:hover {
      border-left-color: #027297; }
    .app .toolbar .content .type-selector .radio.nn:hover {
      border-left-color: #387E25; }
    .app .toolbar .content .type-selector .radio.selected.fp {
      border-left-color: #f2d2c1; }
      .app .toolbar .content .type-selector .radio.selected.fp:hover {
        border-left-color: #f2d2c1; }
    .app .toolbar .content .type-selector .radio.selected.tt {
      border-left-color: #e8dafa; }
      .app .toolbar .content .type-selector .radio.selected.tt:hover {
        border-left-color: #e8dafa; }
    .app .toolbar .content .type-selector .radio.selected.qa {
      border-left-color: #badeea; }
      .app .toolbar .content .type-selector .radio.selected.qa:hover {
        border-left-color: #badeea; }
    .app .toolbar .content .type-selector .radio.selected.nn {
      border-left-color: #b6e7a8; }
      .app .toolbar .content .type-selector .radio.selected.nn:hover {
        border-left-color: #b6e7a8; }
    .app .toolbar .content .states-selector .radio:hover {
      background: #f1f1f1;
      border-left-color: #f1f1f1; }
    .app .toolbar .content .states-selector .radio.selected:hover {
      background: #e6e6e6; }
    .app .toolbar .content header,
    .app .toolbar .content .radio {
      padding: 0.1rem 2.2rem; }
    .app .toolbar .content header {
      border-left: 4px solid #545e69;
      text-transform: uppercase;
      font-weight: 700;
      font-size: 0.85rem;
      background: #545e69;
      color: #fff;
      padding-top: 0.5rem;
      padding-bottom: 0.5rem;
      text-align: center; }
    .app .toolbar .content .radio {
      border-left: 4px solid #F7F7F7;
      position: relative; }
      .app .toolbar .content .radio:before {
        content: '';
        display: block;
        position: absolute;
        width: 14px;
        height: 14px;
        top: 50%;
        left: 10px;
        transform: translate(0, -50%); }
      .app .toolbar .content .radio label {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
            align-items: center;
        cursor: pointer;
        font-size: 0.9rem;
        font-weight: 500;
        -ms-flex-pack: center;
            justify-content: center;
        text-align: center; }
        .app .toolbar .content .radio label svg {
          width: 0.8rem;
          height: 0.8rem;
          margin-right: 0.4rem; }
          .app .toolbar .content .radio label svg.qa {
            fill: #027297; }
          .app .toolbar .content .radio label svg.tt {
            fill: #7344AB; }
          .app .toolbar .content .radio label svg.fp {
            fill: #BE4809; }
          .app .toolbar .content .radio label svg.nn {
            fill: #387E25; }
        .app .toolbar .content .radio label span {
          margin-left: 5px; }
      .app .toolbar .content .radio input {
        margin-right: 0.5rem;
        display: none; }
      .app .toolbar .content .radio.selected {
        border-left-color: #e6e6e6;
        background: #e6e6e6; }
        .app .toolbar .content .radio.selected:before {
          background: url(images/selected.svg); }
    .app .toolbar .content .type-selector .radio.selected {
      border-left-color: #f1f1f1; }
      .app .toolbar .content .type-selector .radio.selected label {
        cursor: default; }
    .app .toolbar .content .type-selector .all-options.selected {
      border-left-color: #e6e6e6;
      background-color: #e6e6e6; }
      .app .toolbar .content .type-selector .all-options.selected:before {
        background: url(images/selected.svg); }
    .app .toolbar .content .type-selector .fp {
      color: #BE4809; }
      .app .toolbar .content .type-selector .fp.selected {
        background: #f2d2c1;
        color: #000; }
        .app .toolbar .content .type-selector .fp.selected:before {
          background: url(images/selected-fp.svg); }
    .app .toolbar .content .type-selector .qa {
      color: #027297; }
      .app .toolbar .content .type-selector .qa.selected {
        background: #badeea;
        color: #000; }
        .app .toolbar .content .type-selector .qa.selected:before {
          background: url(images/selected-qa.svg); }
    .app .toolbar .content .type-selector .tt {
      color: #7344AB; }
      .app .toolbar .content .type-selector .tt.selected {
        background: #e8dafa;
        color: #000; }
        .app .toolbar .content .type-selector .tt.selected:before {
          background: url(images/selected-tt.svg); }
    .app .toolbar .content .type-selector .nn {
      color: #387E25; }
      .app .toolbar .content .type-selector .nn.selected {
        background: #b6e7a8;
        color: #000; }
        .app .toolbar .content .type-selector .nn.selected:before {
          background: url(images/selected-nn.svg); }
  .app .toolbar .toggler {
    -moz-transition: all .2s ease-in-out;
    -ms-transition: all .2s ease-in-out;
    -o-transition: all .2s ease-in-out;
    -webkit-transition: all .2s ease-in-out;
    background: #32363e;
    font-family: nec;
    left: -25px;
    padding: 2em 0;
    position: absolute;
    text-decoration: none;
    top: 50%;
    transform: translate(0, -50%);
    transition: all .2s ease-in-out;
    width: 28px;
    z-index: 91;
    box-shadow: 1px 1px 5px 3px rgba(0, 0, 0, 0.11); }
    .app .toolbar .toggler .icon {
      width: 12px;
      text-align: center;
      margin: 0 auto;
      line-height: 0;
      transition: all .2s ease-in-out;
      fill: #fff; }
  .app .toolbar.show {
    right: 0; }
    .app .toolbar.show .toggler {
      left: -25px; }
      .app .toolbar.show .toggler .icon {
        transform: rotate(180deg); }
  .app .toolbar.fp .content .states-selector .radio.selected {
    border-left-color: #f2d2c1;
    background: #f2d2c1; }
    .app .toolbar.fp .content .states-selector .radio.selected:hover {
      border-left-color: #f2d2c1; }
    .app .toolbar.fp .content .states-selector .radio.selected:before {
      background: url(images/selected-fp.svg); }
  .app .toolbar.fp .content .states-selector .radio label span {
    color: #BE4809; }
  .app .toolbar.qa .content .states-selector .radio.selected {
    border-left-color: #badeea;
    background: #badeea; }
    .app .toolbar.qa .content .states-selector .radio.selected:hover {
      border-left-color: #badeea; }
    .app .toolbar.qa .content .states-selector .radio.selected:before {
      background: url(images/selected-qa.svg); }
  .app .toolbar.qa .content .states-selector .radio label span {
    color: #027297; }
  .app .toolbar.tt .content .states-selector .radio.selected {
    border-left-color: #e8dafa;
    background: #e8dafa; }
    .app .toolbar.tt .content .states-selector .radio.selected:hover {
      border-left-color: #e8dafa; }
    .app .toolbar.tt .content .states-selector .radio.selected:before {
      background: url(images/selected-tt.svg); }
  .app .toolbar.tt .content .states-selector .radio label span {
    color: #7344AB; }
  .app .toolbar.nn .content .states-selector .radio.selected {
    border-left-color: #b6e7a8;
    background: #b6e7a8; }
    .app .toolbar.nn .content .states-selector .radio.selected:hover {
      border-left-color: #b6e7a8; }
    .app .toolbar.nn .content .states-selector .radio.selected:before {
      background: url(images/selected-nn.svg); }
  .app .toolbar.nn .content .states-selector .radio label span {
    color: #387E25; }

.search-panel {
  position: absolute;
  background: #fff;
  padding: 10px;
  top: 0;
  right: 0;
  z-index: 3;
  overflow: hidden; }
  .search-panel form {
    padding-right: 1.5rem;
    position: relative; }
    .search-panel form .search-link {
      position: absolute;
      display: -ms-flexbox;
      display: flex;
      top: 0;
      bottom: 0;
      right: 0;
      -ms-flex-align: center;
          align-items: center; }
      .search-panel form .search-link svg {
        width: 1rem;
        line-height: 0; }
  .search-panel .search-filed-wrapper {
    position: relative; }
    .search-panel .search-filed-wrapper input {
      padding: 5px;
      outline: none;
      padding-right: 25px;
      border: 0;
      border-bottom: 1px solid #b3b3b3; }
    .search-panel .search-filed-wrapper .reset-search {
      right: 10px;
      position: absolute;
      top: 0;
      bottom: 0;
      display: none;
      -ms-flex-align: center;
          align-items: center; }
      .search-panel .search-filed-wrapper .reset-search.show {
        display: -ms-flexbox;
        display: flex; }
      .search-panel .search-filed-wrapper .reset-search svg {
        width: 10px;
        height: 10px; }
  .search-panel .search-button {
    position: absolute;
    top: -1000em; }

.controls-container {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-align: center;
      align-items: center;
  padding: 10px; }
  .controls-container .leaflet-control-zoom {
    margin: 0; }
  .controls-container .center-button {
    display: block;
    margin-top: 10px;
    cursor: pointer;
    position: relative;
    z-index: 800;
    pointer-events: auto; }
    .controls-container .center-button svg {
      fill: #9a9a9a;
      height: 25px;
      opacity: 0.8; }
    .controls-container .center-button:hover svg {
      opacity: 1; }

.\--global-wrap {
  max-width: 1200px;
  margin: 0 auto; }
  .\--global-wrap header {
    overflow: hidden;
    padding: 20px; }
    .\--global-wrap header h1 {
      margin: 0 0 10px 0;
      font-size: 1rem; }
    .\--global-wrap header p {
      font-size: 0.9rem;
      margin-top: 0;
      margin-bottom: 10px; }
  .\--global-wrap .app-wrap {
    position: relative; }

.fha-marker {
  background: rgba(0, 62, 115, 0.8);
  border-radius: 50%;
  border: 1px solid #fff;
  transition: all ease-in 0.2s;
  box-shadow: 0 0 4px 2px rgba(0, 0, 0, 0.1); }
  .fha-marker:hover {
    box-shadow: 0px 0px 0px 4px rgba(0, 62, 115, 0.2); }

.leaflet-cluster-anim .leaflet-marker-icon, .leaflet-cluster-anim .leaflet-marker-shadow {
  transition: transform 0.3s ease-out, opacity 0.3s ease-in; }

.leaflet-cluster-spider-leg {
  /* stroke-dashoffset (duration and function) should match with leaflet-marker-icon transform in order to track it exactly */
  transition: stroke-dashoffset 0.3s ease-out, stroke-opacity 0.3s ease-in; }

.markerClusterIcon {
  border-radius: 50%;
  width: 25px;
  height: 25px;
  background: rgba(50, 55, 61, 0.9);
  text-align: center;
  box-shadow: 0px 0px 0px 4px rgba(50, 55, 61, 0.2);
  transition: all ease-in 0.2s;
  border: 1px solid rgba(255, 255, 255, 0.7);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  text-align: center; }
  .markerClusterIcon strong {
    display: block;
    color: #fff;
    -ms-flex-positive: 1;
        flex-grow: 1; }

.markerClusterIcon:hover {
  background: #32373d;
  box-shadow: 0px 0px 0px 6px rgba(50, 55, 61, 0.25); }

.leaflet-marker-icon svg.qa {
  fill: #027297; }

.leaflet-marker-icon svg.tt {
  fill: #7344AB; }

.leaflet-marker-icon svg.fp {
  fill: #BE4809; }

.leaflet-marker-icon svg.nn {
  fill: #387E25; }

#map.qa .markerClusterIcon {
  background: rgba(2, 114, 151, 0.9);
  box-shadow: 0px 0px 0px 4px rgba(2, 114, 151, 0.2); }

#map.qa .markerClusterIcon:hover {
  background: #027297;
  box-shadow: 0px 0px 0px 6px rgba(2, 114, 151, 0.25); }

#map.tt .markerClusterIcon {
  background: rgba(115, 68, 171, 0.9);
  box-shadow: 0px 0px 0px 4px rgba(115, 68, 171, 0.2); }

#map.tt .markerClusterIcon:hover {
  background: #7344ab;
  box-shadow: 0px 0px 0px 6px rgba(115, 68, 171, 0.25); }

#map.fp .markerClusterIcon {
  background: rgba(190, 72, 9, 0.9);
  box-shadow: 0px 0px 0px 4px rgba(190, 72, 9, 0.2); }

#map.fp .markerClusterIcon:hover {
  background: #be4809;
  box-shadow: 0px 0px 0px 6px rgba(190, 72, 9, 0.25); }

#map.nn .markerClusterIcon {
  background: rgba(56, 126, 37, 0.9);
  box-shadow: 0px 0px 0px 4px rgba(56, 126, 37, 0.2); }

#map.nn .markerClusterIcon:hover {
  background: #387e25;
  box-shadow: 0px 0px 0px 6px rgba(56, 126, 37, 0.25); }
