@charset "UTF-8";
/* required styles */
@import url("https://fonts.googleapis.com/css?family=Lato:300,400,700");
.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;
  -ms-user-select: none;
      user-select: none;
  -webkit-user-drag: none; }

/* 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 {
  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 {
  -webkit-filter: inherit;
          filter: inherit;
  visibility: hidden; }

.leaflet-tile-loaded {
  visibility: inherit; }

.leaflet-zoom-box {
  width: 0;
  height: 0;
  -webkit-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;
  -o-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);
  -o-transition: -o-transform 0.25s cubic-bezier(0, 0, 0.25, 1);
  transition: -webkit-transform 0.25s cubic-bezier(0, 0, 0.25, 1);
  -o-transition: transform 0.25s cubic-bezier(0, 0, 0.25, 1);
  transition: transform 0.25s cubic-bezier(0, 0, 0.25, 1);
  transition: transform 0.25s cubic-bezier(0, 0, 0.25, 1), -webkit-transform 0.25s cubic-bezier(0, 0, 0.25, 1); }

.leaflet-zoom-anim .leaflet-tile,
.leaflet-pan-anim .leaflet-tile {
  -webkit-transition: none;
  -o-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; }

.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; }

/* 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 {
  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 {
  -webkit-box-shadow: 0 1px 5px rgba(0, 0, 0, 0.65);
          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 {
  -webkit-box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4);
          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;
  -webkit-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 {
  -webkit-box-shadow: none;
          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);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg); }

.leaflet-popup-content-wrapper,
.leaflet-popup-tip {
  background: white;
  color: #333;
  -webkit-box-shadow: 0 3px 14px rgba(0, 0, 0, 0.4);
          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 {
  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;
  -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
          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; }

/*! nouislider - 14.1.0 - 12/4/2019 */
/* Functional styling;
 * These styles are required for noUiSlider to function.
 * You don't need to change these rules to apply your design.
 */
.ui-target,
.ui-target * {
  -webkit-touch-callout: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-user-select: none;
  -ms-touch-action: none;
  touch-action: none;
  -ms-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

.ui-target {
  position: relative; }

.ui-base,
.ui-connects {
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 1; }

/* Wrapper for all connect elements.
  */
.ui-connects {
  overflow: hidden;
  z-index: 0; }

.ui-connect,
.ui-origin {
  will-change: transform;
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  -ms-transform-origin: 0 0;
  -webkit-transform-origin: 0 0;
  -webkit-transform-style: preserve-3d;
  transform-origin: 0 0;
  -webkit-transform-style: flat;
          transform-style: flat; }

.ui-connect {
  height: 100%;
  width: 100%; }

.ui-origin {
  height: 10%;
  width: 10%; }

/* Offset direction
  */
.ui-txt-dir-rtl.ui-horizontal .ui-origin {
  left: 0;
  right: auto; }

/* Give origins 0 height/width so they don't interfere with clicking the
  * connect elements.
  */
.ui-vertical .ui-origin {
  width: 0; }

.ui-horizontal .ui-origin {
  height: 0; }

.ui-handle {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  position: absolute; }

.ui-touch-area {
  height: 100%;
  width: 100%; }

.ui-state-tap .ui-connect,
.ui-state-tap .ui-origin {
  -webkit-transition: transform 0.3s;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  -o-transition: transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s; }

.ui-state-drag * {
  cursor: inherit !important; }

/* Slider size and handle placement;
  */
.ui-horizontal {
  height: 18px; }

.ui-horizontal .ui-handle {
  width: 34px;
  height: 28px;
  right: -17px;
  top: -6px; }

.ui-vertical {
  width: 18px; }

.ui-vertical .ui-handle {
  width: 28px;
  height: 34px;
  right: -6px;
  top: -17px; }

.ui-txt-dir-rtl.ui-horizontal .ui-handle {
  left: -17px;
  right: auto; }

/* Styling;
  * Giving the connect element a border radius causes issues with using transform: scale
  */
.ui-target {
  background: #FAFAFA;
  border-radius: 4px;
  border: 1px solid #D3D3D3;
  -webkit-box-shadow: inset 0 1px 1px #F0F0F0, 0 3px 6px -5px #BBB;
          box-shadow: inset 0 1px 1px #F0F0F0, 0 3px 6px -5px #BBB; }

.ui-connects {
  border-radius: 3px; }

.ui-connect {
  background: #3FB8AF; }

/* Handles and cursors;
  */
.ui-draggable {
  cursor: ew-resize; }

.ui-vertical .ui-draggable {
  cursor: ns-resize; }

.ui-handle {
  border: 1px solid #D9D9D9;
  border-radius: 3px;
  background: #FFF;
  cursor: default;
  -webkit-box-shadow: inset 0 0 1px #FFF, inset 0 1px 7px #EBEBEB, 0 3px 6px -3px #BBB;
          box-shadow: inset 0 0 1px #FFF, inset 0 1px 7px #EBEBEB, 0 3px 6px -3px #BBB; }

.ui-active {
  -webkit-box-shadow: inset 0 0 1px #FFF, inset 0 1px 7px #DDD, 0 3px 6px -3px #BBB;
          box-shadow: inset 0 0 1px #FFF, inset 0 1px 7px #DDD, 0 3px 6px -3px #BBB; }

/* Handle stripes;
*/
.ui-handle:before,
.ui-handle:after {
  content: "";
  display: block;
  position: absolute;
  height: 14px;
  width: 1px;
  background: #E8E7E6;
  left: 14px;
  top: 6px; }

.ui-handle:after {
  left: 17px; }

.ui-vertical .ui-handle:before,
.ui-vertical .ui-handle:after {
  width: 14px;
  height: 1px;
  left: 6px;
  top: 14px; }

.ui-vertical .ui-handle:after {
  top: 17px; }

.ui-horizontal {
  height: 4px; }

.ui-horizontal .ui-handle {
  width: 20px;
  height: 20px;
  top: -9px;
  cursor: ew-resize; }
  .ui-horizontal .ui-handle.ui-active {
    width: 25px;
    height: 25px;
    top: -11.5px; }

.ui-vertical {
  width: 18px; }

.ui-vertical .ui-handle {
  width: 28px;
  height: 34px;
  top: -17px;
  cursor: ns-resize; }

.ui-target {
  background: #E0E0E0;
  border-radius: 4px;
  border: 0; }

.ui-connect {
  background: #64B6E7;
  border-radius: 4px;
  -webkit-transition: background 450ms;
  -o-transition: background 450ms;
  transition: background 450ms; }

.ui-handle {
  border: 0;
  border-radius: 9999px;
  background: #64B6E7;
  cursor: default;
  border: 2px solid #FFFFFF;
  outline-color: #FFFFFF;
  -webkit-transition: 300ms ease all;
  -o-transition: 300ms ease all;
  transition: 300ms ease all;
  -webkit-box-shadow: 0 1px 6px 0 rgba(0, 0, 0, 0.1), 0 2px 2px 0 rgba(0, 0, 0, 0.06), 0 0 2px 0 rgba(0, 0, 0, 0.14);
          box-shadow: 0 1px 6px 0 rgba(0, 0, 0, 0.1), 0 2px 2px 0 rgba(0, 0, 0, 0.06), 0 0 2px 0 rgba(0, 0, 0, 0.14); }

.ui-active {
  width: 30px;
  height: 30px; }

/* Handle stripes;
 */
.ui-handle:before,
.ui-handle:after {
  content: none;
  display: block;
  position: absolute;
  height: 14px;
  width: 1px;
  background: #E8E7E6;
  left: 14px;
  top: 6px; }

.ui-handle:after {
  left: 17px; }

.ui-vertical .ui-handle:before,
.ui-vertical .ui-handle:after {
  width: 14px;
  height: 1px;
  left: 6px;
  top: 14px; }

.ui-vertical .ui-handle:after {
  top: 17px; }

/* Base;
 *
 */
.ui-pips,
.ui-pips * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

.ui-pips {
  position: absolute;
  color: #999999; }

/* Values;
 *
 */
.ui-value {
  position: absolute;
  white-space: nowrap;
  text-align: center; }

.ui-value-sub {
  color: #CCCCCC;
  font-size: 10px; }

/* Markings;
 *
 */
.ui-marker {
  position: absolute;
  background: #CCCCCC; }

.ui-marker-sub {
  background: #AAAAAA; }

.ui-marker-large {
  background: #AAAAAA; }

/* Horizontal layout;
 *
 */
.ui-pips-horizontal {
  padding: 10px 0;
  height: 80px;
  top: 100%;
  left: 0;
  width: 100%; }

.ui-value-horizontal {
  -webkit-transform: translate3d(-50%, 50%, 0);
  transform: translate3d(-50%, 50%, 0); }

.ui-marker-horizontal.ui-marker {
  margin-left: -1px;
  width: 2px;
  height: 5px; }

.ui-marker-horizontal.ui-marker-sub {
  height: 10px; }

.ui-marker-horizontal.ui-marker-large {
  height: 15px; }

/* Vertical layout;
 *
 */
.ui-pips-vertical {
  padding: 0 10px;
  height: 100%;
  top: 0;
  left: 100%; }

.ui-value-vertical {
  -webkit-transform: translate3d(0, 50%, 0);
  transform: translate3d(0, 50%, 0);
  padding-left: 25px; }

.ui-marker-vertical.ui-marker {
  width: 5px;
  height: 2px;
  margin-top: -1px; }

.ui-marker-vertical.ui-marker-sub {
  width: 10px; }

.ui-marker-vertical.ui-marker-large {
  width: 15px; }

.ui-tooltip {
  display: block;
  position: absolute;
  border: 1px solid #D9D9D9;
  border-radius: 3px;
  background: #FFFFFF;
  color: #000000;
  padding: 5px;
  text-align: center;
  white-space: nowrap; }

.ui-horizontal .ui-tooltip {
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
      transform: translate(-50%, 0);
  left: 50%;
  bottom: 120%; }

.ui-vertical .ui-tooltip {
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
      transform: translate(0, -50%);
  top: 50%;
  right: 120%; }

@font-face {
  font-family: 'Yummo';
  src: url(../Fonts/yummo_regular.eot);
  src: url(../Fonts/yummo_regular.eot#iefix) format("embedded-opentype"), url(../Fonts/yummo_regular.woff) format("woff");
  font-weight: normal;
  font-style: normal; }

@font-face {
  font-family: 'Yummo';
  src: url(../Fonts/yummo_bold.eot);
  src: url(../Fonts/yummo_bold.eot?#iefix) format("embedded-opentype"), url(../Fonts/yummo_bold.woff) format("woff");
  font-weight: bold;
  font-style: normal; }

@font-face {
  font-family: 'Yummo';
  src: url(../Fonts/yummo_light.eot);
  src: url(../Fonts/yummo_light.eot?#iefix) format("embedded-opentype"), url(../Fonts/yummo_light.woff) format("woff");
  font-weight: 300;
  font-style: normal; }

@font-face {
  font-family: 'Yummo';
  src: url(../Fonts/yummo_semi.eot);
  src: url(../Fonts/yummo_semi.eot?#iefix) format("embedded-opentype"), url(../Fonts/yummo_semi.woff) format("woff");
  font-weight: 600;
  font-style: normal; }

@font-face {
  font-family: 'TFWIconFont';
  src: url(../Fonts/tfwImmoIconFont.eot?rqp9j6);
  src: url(../Fonts/tfwImmoIconFont.eot?rqp9j6#iefix) format("embedded-opentype"), url(../Fonts/tfwImmoIconFont.ttf?rqp9j6) format("truetype"), url(../Fonts/tfwImmoIconFont.woff?rqp9j6) format("woff"), url(../Fonts/tfwImmoIconFont.woff2?rqp9j6) format("woff2"), url(../Fonts/tfwImmoIconFont.svg?rqp9j6#icomoon) format("svg");
  font-weight: normal;
  font-style: normal; }

/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */
/* Plus our own additional settings (Mogic) */
/* Border-Box everywhere */
*, *:before, *:after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; }

/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Prevent adjustments of font size after orientation changes in IE and iOS.
 *
 * 3. Optmize font rendering.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  text-rendering: optimizeLegibility;
  /* 3 */
  -webkit-font-smoothing: antialiased;
  /* 3 */
  -moz-osx-font-smoothing: grayscale;
  /* 3 */
  text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.004);
  /* 3 */ }

/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0; }

/* HTML5 display definitions
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 * 2. Add the correct display in IE.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  /* 1 */
  display: block; }

/**
 * Add the correct display in IE 9-.
 */
audio,
canvas,
progress,
video {
  display: inline-block; }

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline; }

/**
 * Add the correct display in IE 10-.
 * 1. Add the correct display in IE.
 */
template,
[hidden] {
  display: none; }

/* Links
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
  background-color: transparent;
  /* 1 */
  -webkit-text-decoration-skip: objects;
  /* 2 */
  color: inherit;
  text-decoration: none; }

/**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
a:active,
a:hover {
  outline-width: 0; }

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  /* 2 */ }

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
  font-weight: inherit; }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
  font-style: italic; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/**
 * Add the correct background and color in IE 9-.
 */
mark {
  background-color: #ff0;
  color: #000; }

/**
 * 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; }

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden; }

/* Grouping content
   ========================================================================== */
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct margin in IE 8.
 */
figure {
  margin: 1em 40px; }

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/* Forms
   ========================================================================== */
/**
 * 1. Change font properties to `inherit` in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
select,
textarea {
  font: inherit;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Restore the font weight unset by the previous rule.
 */
optgroup {
  font-weight: bold; }

/**
 * 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; }

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* 2 */ }

/**
 * 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; }

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

/**
 * 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 {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type="checkbox"],
[type="radio"] {
  -webkit-box-sizing: border-box;
          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 and cancel buttons in Chrome and Safari on OS X.
 */
[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * Correct the text style of placeholders in Chrome, Edge, and Safari.
 */
::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54; }

/**
 * 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 */ }

html {
  font-family: "Lato", Arial, Helvetica, sans-serif;
  font-size: 100%;
  font-weight: 300; }

p, ul, ol {
  margin: 0 0 0.75rem;
  line-height: 1.5em; }

ul, ol {
  list-style-type: none;
  margin: 0;
  padding: 0; }

b,
strong {
  font-weight: bold; }

.label--h1 {
  font-size: 2.8125rem; }

.label--h2 {
  font-size: 2.125rem; }

.label--h3 {
  font-size: 1.5rem; }

.label--h4 {
  font-size: 1.25rem; }

.label--h5 {
  font-size: 1.125rem; }

.label--h6 {
  font-size: 1rem; }

.label--medium {
  font-size: 1.125rem; }

.label--small {
  font-size: 1rem; }

.label--tiny {
  font-size: 0.875rem; }

.label--xxs {
  font-size: 0.75rem; }

.label--bold {
  font-weight: bold; }

p {
  line-height: 1.71;
  font-size: 1rem; }

.filter {
  padding: 20px;
  background: #FFFFFF;
  -webkit-transition: all ease 300ms;
  -o-transition: all ease 300ms;
  transition: all ease 300ms; }
  @media (min-width: 1024px) {
    .filter {
      -ms-flex-preferred-size: 23.72881%;
          flex-basis: 23.72881%;
      border-radius: 6px;
      -webkit-box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.1), 0 3px 4px 0 rgba(0, 0, 0, 0.06), 0 2px 4px 0 rgba(0, 0, 0, 0.14);
              box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.1), 0 3px 4px 0 rgba(0, 0, 0, 0.06), 0 2px 4px 0 rgba(0, 0, 0, 0.14); } }
  .filter__header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row wrap;
            flex-flow: row wrap;
    padding: 25px 0; }
    @media (min-width: 1024px) {
      .filter__header {
        border-radius: 6px 6px 0 0;
        background: #F7F7F7;
        margin: -20px -20px 0 -20px;
        padding: 25px 20px; } }
    .filter__header > h3 {
      -ms-flex-negative: 1;
          flex-shrink: 1;
      -webkit-box-flex: 1;
          -ms-flex-positive: 1;
              flex-grow: 1;
      -ms-flex-preferred-size: auto;
          flex-basis: auto;
      line-height: 1;
      margin-bottom: 0; }
    .filter__header .header__reset {
      -ms-flex-negative: 1;
          flex-shrink: 1;
      -webkit-box-flex: 1;
          -ms-flex-positive: 1;
              flex-grow: 1;
      -ms-flex-preferred-size: auto;
          flex-basis: auto;
      text-align: right; }
      .filter__header .header__reset .cta {
        position: relative;
        font-size: 0.875rem;
        color: #9E9E9E;
        background: transparent;
        padding-right: 25px; }
        .filter__header .header__reset .cta:hover {
          color: #757575; }
      .filter__header .header__reset .icon {
        height: 20px;
        width: 20px;
        margin-left: 5px;
        padding: 2px;
        display: inline-block;
        line-height: 18px;
        text-align: center;
        top: 0;
        right: 0;
        font-size: 10px;
        position: absolute;
        color: #FFFFFF;
        border-radius: 9999px;
        background: #E0E0E0; }
  .filter__toggle {
    padding: 10px 0;
    margin-bottom: 5.26316%;
    z-index: 6;
    top: 79px !important;
    position: relative; }
    .site--detail.site--expose .filter__toggle {
      z-index: 12; }
    .filter__toggle:before {
      content: "";
      display: block;
      position: absolute;
      top: 0px;
      width: 100vw;
      height: 100%;
      margin-left: calc(50% - 50vw);
      margin-right: calc(50% - 50vw);
      background-color: #E0E0E0; }
    .filter__toggle > * {
      position: relative; }
    .filter__toggle .selectize-input {
      padding: 7px 12px; }
    .filter__toggle select, .filter__toggle .selectize-control, .filter__toggle .selectize-input {
      height: 40px;
      line-height: 23px;
      float: right;
      width: 200px; }
      @media (min-width: 0px) and (max-width: 479px) {
        .filter__toggle select, .filter__toggle .selectize-control, .filter__toggle .selectize-input {
          font-size: 1rem;
          width: 120px; } }
    @media (min-width: 0px) and (max-width: 479px) {
      .filter__toggle .selectize-dropdown {
        padding: 0; } }
    @media (min-width: 0px) and (max-width: 479px) {
      .filter__toggle .selectize-dropdown [data-selectable].option {
        font-size: 0.875rem; } }
    .filter__toggle .cta {
      white-space: nowrap;
      -webkit-box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.1), 0 3px 4px 0 rgba(0, 0, 0, 0.06), 0 2px 4px 0 rgba(0, 0, 0, 0.14);
              box-shadow: 0 1px 10px 0 rgba(0, 0, 0, 0.1), 0 3px 4px 0 rgba(0, 0, 0, 0.06), 0 2px 4px 0 rgba(0, 0, 0, 0.14); }
    .filter__toggle > * {
      -webkit-box-flex: 1;
          -ms-flex: 1 50%;
              flex: 1 50%; }
      .filter__toggle > *:first-child {
        margin-right: 6px; }
      @media (min-width: 640px) {
        .filter__toggle > * {
          -webkit-box-flex: 0;
              -ms-flex-positive: 0;
                  flex-grow: 0;
          -ms-flex-negative: 1;
              flex-shrink: 1;
          -ms-flex-preferred-size: auto;
              flex-basis: auto; } }
    @media (min-width: 1024px) {
      .filter__toggle {
        display: none; } }
  .filter > [class*="filter__"]:not(:first-child) {
    margin-top: 5.26316%; }
  .filter [class$="__label"]:not(.checkbox__label) {
    display: inline-block;
    margin-bottom: 5px;
    width: 100%;
    font-size: 1rem; }
  .filter__checkboxes, .iconlist--labels {
    margin: 10px 0; }
    .filter__checkboxes ul, .iconlist--labels ul, .filter__checkboxes li, .iconlist--labels li {
      list-style: none;
      margin: 0;
      padding: 0; }
    .filter__checkboxes li, .iconlist--labels li {
      display: block; }
      .filter__checkboxes li:not(:last-child), .iconlist--labels li:not(:last-child) {
        margin-bottom: 15px; }
    .filter__checkboxes input[type=checkbox], .iconlist--labels input[type=checkbox] {
      display: none; }
    .filter__checkboxes .checkbox__label, .iconlist--labels .checkbox__label, .filter__checkboxes [class*=__label], .iconlist--labels [class*=__label] {
      line-height: 40px;
      display: inline-block;
      cursor: pointer;
      width: 100%;
      position: relative;
      padding-right: 8%;
      -webkit-user-select: none;
         -moz-user-select: none;
          -ms-user-select: none;
              user-select: none;
      font-size: 1rem; }
      .filter__checkboxes .checkbox__label:hover .icon, .iconlist--labels .checkbox__label:hover .icon, .filter__checkboxes [class*=__label]:hover .icon, .iconlist--labels [class*=__label]:hover .icon {
        color: #212121;
        border-color: #212121; }
    .filter__checkboxes .icon, .iconlist--labels .icon {
      float: left;
      display: block;
      width: 40px;
      height: 40px;
      border: 1px solid #9E9E9E;
      margin-right: 15px;
      font-size: 24px;
      line-height: 40px;
      text-align: center;
      -webkit-transition: all 250ms ease;
      -o-transition: all 250ms ease;
      transition: all 250ms ease;
      color: #9E9E9E;
      border-radius: 50%; }
    .filter__checkboxes .filter__checkbox, .iconlist--labels .filter__checkbox {
      display: none; }
      .filter__checkboxes .filter__checkbox:checked + .checkbox__label .icon, .iconlist--labels .filter__checkbox:checked + .checkbox__label .icon {
        color: #FFFFFF;
        border-color: #64B6E7;
        background-color: #64B6E7; }
  .filter__select {
    margin-bottom: 2.63158%; }
  .filter__range {
    margin-bottom: 2.63158%; }
    .filter__range .range__values {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; }
      .filter__range .range__values input {
        -webkit-box-flex: 2;
            -ms-flex: 2 0;
                flex: 2 0; }
      .filter__range .range__values span {
        -webkit-box-flex: 1;
            -ms-flex: 1 0;
                flex: 1 0;
        text-align: center; }
    .filter__range .range__labels {
      position: relative;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between; }
      .filter__range .range__labels .range__label {
        display: inline;
        width: auto;
        -webkit-box-flex: 0;
            -ms-flex-positive: 0;
                flex-grow: 0;
        -ms-flex-negative: 1;
            flex-shrink: 1;
        -ms-flex-preferred-size: auto;
            flex-basis: auto;
        font-size: 1rem;
        color: #757575; }
    .filter__range .filter__range-slider {
      margin: 2.63158% 0; }
    .filter__range .ui-horizontal + .range__values--inputs {
      display: none; }
  .filter__input {
    margin-bottom: 2.63158%; }
    .filter__input--two {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; }
      .filter__input--two input {
        -webkit-box-flex: 2;
            -ms-flex: 2 0;
                flex: 2 0; }
      .filter__input--two span {
        -webkit-box-flex: 1;
            -ms-flex: 1 0;
                flex: 1 0;
        text-align: center; }
  .filter__submit {
    display: block; }
    @media (min-width: 1024px) {
      .filter__submit {
        display: none; } }
    .filter__submit > * {
      width: 100%; }
  .filter__more {
    text-align: center; }
    .filter__more label {
      cursor: pointer;
      -webkit-user-select: none;
         -moz-user-select: none;
          -ms-user-select: none;
              user-select: none;
      color: #757575; }
    .filter__more .icon {
      display: block;
      margin: 2px auto;
      height: 24px;
      width: 24px;
      font-size: 24px;
      color: #757575; }
  .filter__more-container {
    display: none; }
  .filter #more-filter {
    display: none; }
    .filter #more-filter:checked ~ .filter__more-container {
      display: block; }
    .filter #more-filter:checked ~ .filter__more {
      display: none; }
  .overlay--filter .filter {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    padding-top: 0; }
    @media (min-width: 640px) and (max-width: 767px) {
      .overlay--filter .filter {
        padding-left: 29px;
        padding-right: 29px; } }
    @media (min-width: 0px) and (max-width: 479px) {
      .overlay--filter .filter {
        padding: 0; } }
    .overlay--filter .filter .filter__checkboxes, .overlay--filter .filter .iconlist--labels {
      margin-top: 0;
      margin-bottom: 2.63158%; }
      .overlay--filter .filter .filter__checkboxes ul, .overlay--filter .filter .iconlist--labels ul {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
            -ms-flex-flow: row wrap;
                flex-flow: row wrap; }
      .overlay--filter .filter .filter__checkboxes li, .overlay--filter .filter .iconlist--labels li {
        -webkit-box-flex: 1;
            -ms-flex-positive: 1;
                flex-grow: 1;
        -ms-flex-negative: 1;
            flex-shrink: 1;
        -ms-flex-preferred-size: 100%;
            flex-basis: 100%; }
        .overlay--filter .filter .filter__checkboxes li .checkbox__label, .overlay--filter .filter .iconlist--labels li .checkbox__label, .overlay--filter .filter .filter__checkboxes li [class*=__label], .overlay--filter .filter .iconlist--labels li [class*=__label] {
          line-height: 30px;
          padding-right: 8px;
          -webkit-user-select: none;
             -moz-user-select: none;
              -ms-user-select: none;
                  user-select: none;
          font-size: 1rem; }
          .overlay--filter .filter .filter__checkboxes li .checkbox__label .icon, .overlay--filter .filter .iconlist--labels li .checkbox__label .icon, .overlay--filter .filter .filter__checkboxes li [class*=__label] .icon, .overlay--filter .filter .iconlist--labels li [class*=__label] .icon {
            width: 30px;
            height: 30px;
            margin-right: 8px;
            font-size: 16px;
            line-height: 30px; }
        @media (min-width: 640px) {
          .overlay--filter .filter .filter__checkboxes li, .overlay--filter .filter .iconlist--labels li {
            -webkit-box-flex: 1;
                -ms-flex: 1 50%;
                    flex: 1 50%; } }
        @media (min-width: 1024px) {
          .overlay--filter .filter .filter__checkboxes li, .overlay--filter .filter .iconlist--labels li {
            -webkit-box-flex: 1;
                -ms-flex: 1 30%;
                    flex: 1 30%; } }
    .overlay--filter .filter .filter__select .selectize-input {
      border: 1px solid #E0E0E0;
      padding: 0 12px; }
    .overlay--filter .filter .filter__more-container {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: horizontal;
      -webkit-box-direction: normal;
          -ms-flex-flow: row wrap;
              flex-flow: row wrap; }
      .overlay--filter .filter .filter__more-container > * {
        margin-bottom: 5.26316%;
        -webkit-box-flex: 1;
            -ms-flex-positive: 1;
                flex-grow: 1;
        -ms-flex-negative: 1;
            flex-shrink: 1;
        -ms-flex-preferred-size: 100%;
            flex-basis: 100%; }
        @media (min-width: 640px) {
          .overlay--filter .filter .filter__more-container > * {
            -webkit-box-flex: 1;
                -ms-flex: 1 40.67797%;
                    flex: 1 40.67797%;
            margin: 0 6.31579% 6.31579% 0; } }
    .overlay--filter .filter .filter__more {
      display: none; }
    .overlay--filter .filter .filter__submit > * {
      line-height: 32px;
      width: 100%;
      margin: 0 auto;
      display: block; }
    .overlay--filter .filter .filter__submit > .js-toggle {
      display: none; }

.iconlist {
  position: relative;
  top: auto;
  left: auto;
  margin: 2.63158% 0; }
  .iconlist li {
    margin-bottom: .5rem; }
    .iconlist li[data-tooltip] {
      cursor: pointer; }
  .iconlist--labels ul {
    *zoom: 1; }
    .iconlist--labels ul:after {
      content: "";
      display: table;
      clear: both; }
    .iconlist--labels ul li.iconlist__item {
      float: left;
      width: 100%;
      margin: 0;
      padding-right: 2.63158%; }
      @media (min-width: 640px) {
        .iconlist--labels ul li.iconlist__item {
          width: 50%; } }
      @media (min-width: 1024px) {
        .iconlist--labels ul li.iconlist__item {
          width: 40%; } }
      .iconlist--labels ul li.iconlist__item:not(:last-child) {
        margin-bottom: 0; }
      .iconlist--labels ul li.iconlist__item span[class*=__label] {
        width: auto;
        padding-right: 0;
        vertical-align: bottom; }
      .iconlist--labels ul li.iconlist__item .iconlist__icon {
        display: inline-block;
        float: none;
        margin-top: 10px; }

.icon {
  font-family: "TFWIconFont";
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-style: normal;
  font-weight: normal;
  line-height: 1;
  text-transform: none;
  speak: none;
  font-variant: normal; }

.icon--globe:before {
  content: ""; }

.icon--location:before {
  content: ""; }

.icon--euro:before {
  content: ""; }

.icon--house:before {
  content: ""; }

.icon--chevron-up:before {
  content: ""; }

.icon--chevron-right:before {
  content: ""; }

.icon--chevron-down:before {
  content: ""; }

.icon--chevron-left:before {
  content: ""; }

.icon--garten:before {
  content: ""; }

.icon--gartennutzung:before {
  content: ""; }

.icon--gartenflaeche:before {
  content: ""; }

.icon--phone:before {
  content: ""; }

.icon--arrow-right:before {
  content: ""; }

.icon--arrow-left:before {
  content: ""; }

.icon--share:before {
  content: ""; }

.icon--heart:before {
  content: ""; }

.icon--heart-filled:before {
  content: ""; }

.icon--garage:before {
  content: ""; }

.icon--hallenbad:before {
  content: ""; }

.icon--swimmingpool:before {
  content: ""; }

.icon--fahrstuhl:before {
  content: ""; }

.icon--balkon:before {
  content: ""; }

.icon--gastterasse:before {
  content: ""; }

.icon--stellplatz:before {
  content: ""; }

.icon--account:before {
  content: ""; }

.icon--klimatisiert:before {
  content: ""; }

.icon--klimaanlage:before {
  content: ""; }

.icon--chair:before {
  content: ""; }

.icon--moebliert:before {
  content: ""; }

.icon--moebliert_teilmoebliert:before {
  content: ""; }

.icon--teilmoebliert:before {
  content: ""; }

.icon--sauna:before {
  content: ""; }

.icon--close:before {
  content: ""; }

.icon--check:before {
  content: ""; }

.icon--checkmark:before {
  content: ""; }

.icon--instagram:before {
  content: ""; }

.icon--mail:before {
  content: ""; }

.icon--printer:before {
  content: ""; }

.icon--facebook:before {
  content: ""; }

.icon--search:before {
  content: ""; }

.icon--settings:before {
  content: ""; }

.icon--wlan:before {
  content: ""; }

.icon--camera:before {
  content: ""; }

.icon--minus:before {
  content: ""; }

.icon--play:before {
  content: ""; }

.icon--location-pin:before {
  content: ""; }

.icon--dog:before {
  content: ""; }

.icon--pinterest:before {
  content: ""; }

.icon--twitter:before {
  content: ""; }

.icon--garage_stellplatz:before {
  content: ""; }

.icon--account-2:before {
  content: ""; }

.icon--diagramm:before {
  content: ""; }

.icon--avatarbusiness:before {
  content: ""; }

.icon--avatarprivat:before {
  content: ""; }

.icon--frame:before {
  content: ""; }

.icon--bubble:before {
  content: ""; }

.icon--house-star:before {
  content: ""; }

.icon--house-money:before {
  content: ""; }

.icon--house-family:before {
  content: ""; }

.icon--house-bubble:before {
  content: ""; }

.icon--rectangle:before {
  content: ""; }

.icon--tree:before {
  content: ""; }

.icon--modernhouse:before {
  content: ""; }

.icon--shelf:before {
  content: ""; }

.icon--light:before {
  content: ""; }

.icon--envelope:before {
  content: ""; }

.icon--agent:before {
  content: ""; }

.icon--advertising:before {
  content: ""; }

.icon--info:before {
  content: ""; }

.logo {
  display: block;
  width: 179px;
  height: 40px;
  margin: 0;
  text-indent: -9999em;
  text-shadow: none;
  background: url("../Images/logo.svg") no-repeat center left;
  background-size: contain;
  -webkit-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease; }
  @media (min-width: 1024px) {
    .logo {
      width: 230px;
      height: 65px; } }
  .logo--with-text {
    background: url("../Images/logo--with-text.svg") no-repeat center left; }
  .logo--tfw-with-text {
    background: url("../Images/tfwlogo--with-text.svg") no-repeat center left; }

*,
*::before,
*::after {
  color: #000 !important;
  text-shadow: none !important;
  background-color: transparent !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  -webkit-transition: none !important;
  -o-transition: none !important;
  transition: none !important; }

body {
  padding: 0 1cm 1cm;
  position: relative !important; }

a,
a:visited {
  text-decoration: underline; }

abbr[title]::after {
  content: " (" attr(title) ")"; }

pre {
  white-space: pre-wrap !important; }

pre,
blockquote {
  page-break-inside: avoid; }

thead {
  display: table-header-group; }

tr,
img {
  page-break-inside: avoid; }

p,
h2,
h3 {
  orphans: 3;
  widows: 3; }

h2,
h3 {
  page-break-after: avoid; }

img {
  max-width: 15cm;
  height: auto; }

.site__content,
.article-box {
  padding: 0;
  margin: 0; }

.quote__text:before {
  display: none; }

.article-header__block,
.related-articles,
.site__footer,
.owl-item:not(.active),
.owl-nav,
.blur-svg,
.video-box {
  display: none !important; }

.panel__content {
  max-height: 10000px !important;
  padding: 0 10px 1.35rem 36px !important; }

.article {
  padding-top: 0 !important; }

.article-header {
  position: static !important;
  top: 0 !important;
  -webkit-transform: translateY(0) !important;
      -ms-transform: translateY(0) !important;
          transform: translateY(0) !important;
  border-bottom: 1px solid rgba(168, 173, 179, 0.5);
  height: auto; }

.article-header__title {
  padding: 0;
  margin: 0 0 1.3rem 0 !important;
  font-size: 2.25rem !important; }

.article-header__category-list {
  display: block !important; }

.box {
  padding-left: 0.5cm !important;
  padding-right: 0.5cm !important; }

#main {
  margin-top: 0; }

.quote__text:before,
.article-header__block,
.related-articles,
.site__footer,
.owl-item:not(.active),
.owl-nav,
.blur-svg,
.video-box,
.site-header__container > *,
.site-header__menu-toggle,
.site-header__main-menu-dropdown,
.site-header__main-menu,
.main-menu__list,
.breadcrumb,
.site-footer__nav,
.site-footer__social,
.site-footer,
.site-footer--sticky,
.cookie-banner,
.action-bar, .container--expose .sidebar .form-container .block--bg-soft-blue,
.location__link,
.contact__actions > .cta--button,
.contact__actions > ul > li > a,
.contact__actions > ul > li > div#estateBrokerContactPhone > a,
.contact__actions > ul > li > div#estateContactPhone > a,
.contact > .contact__details > .contact__info > .contact__name > a,
.card__bookmark, .map__link,
.block--expose-files, .overlay, #perfanalysis,
.excerpt > p,
.excerpt .excerpt__trigger,
.leaflet-control-container,
.filter__toggle,
.pagination,
.card__cta,
.stage__search,
.stage__teaser,
.breadcrumb--stage,
.stage__background picture,
.link-list__item .icon {
  display: none; }

html {
  max-width: 8.67in; }

body {
  background: #fff;
  line-height: 1.5; }

p {
  line-height: 1.5;
  margin: 0 0 0.75rem !important; }

.site {
  position: relative; }

.block__content h3 {
  font-size: 1rem; }

.block__header .header__title {
  font-family: "Lato", Arial, Helvetica, sans-serif;
  font-weight: bold;
  font-size: 1.5rem; }

.block__content h1, .block__content h2, .block__content h3, .block__content h4, .block__content h5, .block__content h6 {
  line-height: 1.19;
  margin: 1.2rem 0 0.3rem 0; }

.block.block--with-boxshadow {
  box-shadow: none;
  -webkit-box-shadow: none; }

.contact__numbers-item a {
  text-decoration: none; }

.contact .contact__details .contact__info .contact__image {
  -ms-flex-preferred-size: 160px;
      flex-basis: 160px; }

.contact .contact__details .contact__info .contact__image .image-container {
  border: none;
  padding-left: 0; }

.contact .contact__actions {
  border-left: none; }

.contact .contact__actions li {
  border-bottom: none; }

.contact--person .contact__actions {
  border-top: none; }

.excerpt .excerpt__extendable {
  display: block; }

.fact-list li {
  border-bottom: none; }

.gallery__navigation {
  display: none; }

.image-box__visual {
  border-radius: 0; }

.gallery {
  display: inline-block;
  margin: 1rem;
  width: auto; }
  .gallery .slick-track {
    width: 100% !important; }
  .gallery__slide {
    display: none; }
    .gallery__slide:first-child {
      position: relative;
      display: block;
      width: 100% !important; }
      .gallery__slide:first-child .image-box__visual {
        background-color: transparent; }
        .gallery__slide:first-child .image-box__visual img {
          width: auto;
          max-width: 100%;
          max-height: 60vh; }
      .gallery__slide:first-child .image-box__caption {
        position: absolute;
        bottom: 1rem;
        width: 100%;
        text-align: center; }
        .gallery__slide:first-child .image-box__caption p {
          padding: 5px 15px 6px !important;
          background: #FFFFFF !important;
          border-radius: 20px;
          display: inline-block;
          -webkit-print-color-adjust: exact;
          color-adjust: exact; }
  .gallery__actions {
    display: none; }

.map {
  display: none; }

.graph--expose .graph-wrapper {
  padding-top: 0; }

.iconlist__item .iconlist__label::before {
  content: "   ";
  white-space: pre; }

.card--project .card__text-container a,
.card--project .card__label,
.card--project .card__image {
  display: none !important; }

.section--content a.teaser,
.section--content a.card--project {
  text-decoration: none; }

.link-list__item {
  display: inline-block;
  width: 25%;
  padding: .5rem 1rem; }

.slider__actions {
  display: none; }

.section__header h2 {
  text-align: center; }

.section__content + .section__footer {
  display: none; }

.container--sel .searchbox,
.container--sel .sidebar .filter,
.container--sel .section .section__footer,
.container--sel .card-container--sel .card--item .cta--button {
  display: none; }

.site-header {
  position: relative; }
  .site-header__home {
    display: block;
    margin: 1rem 0; }
    .site-header__home .home__link {
      display: block;
      position: relative; }
      .site-header__home .home__link .logo {
        -webkit-print-color-adjust: exact;
        color-adjust: exact;
        height: 100px; }
        .site-header__home .home__link .logo:before {
          display: block !important;
          height: 100px;
          content: url("../Images/logo--with-text.svg"); }

.stage {
  height: 200px; }
  .stage__container {
    position: absolute;
    width: 100%;
    height: 100%;
    text-align: center; }

.card {
  overflow: hidden;
  *zoom: 1;
  padding-bottom: 1.5rem;
  margin-bottom: 1.5rem;
  border-bottom: 1px solid whitesmoke;
  height: auto !important; }
  .card__title {
    font-size: 1.25rem;
    line-height: 1.2em;
    font-weight: bold; }
  .card__features, .card__spec-list {
    margin: 0 0 20px !important; }
    .card__features li, .card__spec-list li {
      display: inline-block; }
  .card__price {
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.2em;
    display: block;
    margin-bottom: 0 !important; }
  .card .teaser__shorttext {
    margin: 20px 0 !important; }
  .card__image {
    float: left; }
    .card__image img {
      margin-right: 30px !important;
      margin-bottom: 30px !important; }

.container--detail .detail {
  width: 100%; }

.detail .highlights ul li {
  display: inline-block;
  width: 24%;
  padding: 1rem;
  text-align: center; }
  .detail .highlights ul li > span {
    display: block; }
    .detail .highlights ul li > span.highlights__value {
      font-weight: bold; }

.detail .highlights + a {
  display: none; }

.detail .location {
  margin: 1rem 0; }
  .detail .location__name {
    width: 50%;
    display: inline-block;
    text-align: left; }
  .detail .location__id {
    width: 49%;
    display: inline-block;
    text-align: right; }

.detail .fact-list {
  margin: 1rem 0; }
  .detail .fact-list li {
    padding: .25rem 0; }
  .detail .fact-list__key, .detail .fact-list__value {
    width: 49%;
    display: inline-block; }

.detail .block.block--contact:before,
.detail .block.block--expose-map:before,
.detail .block.block--marketdata:before {
  content: "";
  display: block;
  page-break-before: always; }

.detail .block.block--expose-map:after,
.detail .block.block--gallery .gallery__slides:after {
  content: "";
  display: block;
  page-break-after: always; }

.detail .map {
  display: block;
  margin: 1rem; }
  .detail .map .map__container {
    height: 400px; }
  .detail .map .leaflet-container {
    position: relative;
    height: 100%; }
  .detail .map .leaflet-pane, .detail .map .leaflet-tile, .detail .map .leaflet-marker-icon, .detail .map .leaflet-marker-shadow, .detail .map .leaflet-tile-container, .detail .map .leaflet-pane > svg, .detail .map .leaflet-pane > canvas, .detail .map .leaflet-zoom-box, .detail .map .leaflet-image-layer, .detail .map .leaflet-layer {
    position: absolute; }

.detail .contact__details {
  overflow: hidden;
  *zoom: 1;
  position: relative;
  padding-bottom: 2rem; }

.detail .contact__name {
  position: relative;
  float: left; }

.detail .contact__image--person {
  position: relative;
  float: left;
  margin-right: 30px !important; }
  .detail .contact__image--person .image-container {
    width: 160px;
    overflow: hidden;
    height: 160px;
    border-radius: 9999px;
    border: 0;
    padding: 0;
    margin: 0; }
    .detail .contact__image--person .image-container > * {
      width: auto;
      height: 100%;
      max-width: none; }
  .detail .contact__image--person + .contact__image {
    position: absolute;
    top: 100px;
    left: 60px; }
    .detail .contact__image--person + .contact__image .image-container {
      background: #FFFFFF !important;
      border-radius: 10px;
      border: 1px solid #9E9E9E !important;
      padding: .25rem .5rem !important;
      -webkit-print-color-adjust: exact;
      color-adjust: exact; }
      .detail .contact__image--person + .contact__image .image-container > * {
        height: 40px; }

.detail .contact__numbers-item {
  line-height: 45px; }
  .detail .contact__numbers-item .label {
    font-weight: bold; }

.detail + .sidebar .contact {
  overflow: hidden;
  *zoom: 1; }
  .detail + .sidebar .contact__details {
    padding-top: 13px; }
  .detail + .sidebar .contact__name .name {
    display: block; }
  .detail + .sidebar .contact__name .street {
    display: block; }
  .detail + .sidebar .contact__numbers-item {
    line-height: 45px; }
    .detail + .sidebar .contact__numbers-item .label {
      font-weight: bold; }
  .detail + .sidebar .contact__image {
    position: relative;
    float: left;
    margin-right: 30px !important; }
    .detail + .sidebar .contact__image .image-container {
      width: 100px;
      height: 100px; }
      .detail + .sidebar .contact__image .image-container > * {
        border-radius: 9999px;
        width: 100%;
        height: auto;
        max-width: none; }

.detail .excerpt > p:last-child,
.detail .excerpt .excerpt__trigger + .excerpt__extendable {
  display: block; }

.detail .excerpt .excerpt__trigger + .excerpt__extendable {
  display: block; }

.detail .excerpt .excerpt__trigger {
  display: none; }

[data-tooltip]:not(.iconlist__item):after {
  content: attr(data-tooltip);
  margin: 0 .5rem !important; }

.container a[name="estates"]:before {
  display: block;
  content: "";
  page-break-before: always; }

.slick-track {
  width: 100% !important; }

.graph {
  margin: 0; }
  .graph-wrapper {
    position: relative;
    width: 100%;
    padding-top: 50%;
    margin-top: 1.5rem; }
    .graph-wrapper svg {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
  .graph--expose .graph-wrapper {
    padding-top: 65%; }
  .graph .grid-group .graph .grid {
    opacity: 0;
    -webkit-transition: opacity .25s ease-in;
    -o-transition: opacity .25s ease-in;
    transition: opacity .25s ease-in;
    stroke: #f7f7f7;
    stroke-dasharray: 0;
    stroke-width: 1; }
  .graph .grid-group--stay .graph .grid {
    stroke: #64B6E7; }
  .graph .grid-group--stay .grid-labels text {
    fill: #64B6E7; }
  .graph .grid-group--priceperday .graph .grid {
    stroke: #FDC400; }
  .graph .grid-group--priceperday .grid-labels text {
    fill: #FDC400; }
  .graph .grid-group--months .grid-labels {
    font-weight: bold; }
  .graph .grid-group .grid-labels {
    font-size: 12px;
    letter-spacing: -0.8px;
    -webkit-transition: opacity .25s ease-in;
    -o-transition: opacity .25s ease-in;
    transition: opacity .25s ease-in; }
  .graph .grid-group.graph--triggered ~ .graph .grid-group .graph .grid {
    opacity: .2;
    -webkit-transition: opacity .25s ease-in;
    -o-transition: opacity .25s ease-in;
    transition: opacity .25s ease-in; }
  .graph .grid-group.graph--triggered ~ .graph .grid-group .grid-labels {
    opacity: .2;
    -webkit-transition: opacity .25s ease-in;
    -o-transition: opacity .25s ease-in;
    transition: opacity .25s ease-in; }
  .graph .grid-group.graph--triggered .graph .grid {
    opacity: 1;
    -webkit-transition: opacity .25s ease-out;
    -o-transition: opacity .25s ease-out;
    transition: opacity .25s ease-out; }
  .graph .grid-group.graph--triggered .grid-labels {
    opacity: 1;
    -webkit-transition: opacity .25s ease-out;
    -o-transition: opacity .25s ease-out;
    transition: opacity .25s ease-out; }
  .graph .grid-rects .grid-rect-item {
    fill: #f7f7f7;
    stroke: #ffffff;
    stroke-dasharray: 0;
    stroke-width: 1; }
  .graph .chart-group {
    position: relative; }
  .graph .chart--line-line {
    stroke: #FDC400;
    stroke-dasharray: 0;
    stroke-width: 1; }
  .graph .chart-circle--item > circle {
    position: relative;
    cursor: pointer;
    opacity: .7;
    -webkit-transition: opacity .5 ease;
    -o-transition: opacity .5 ease;
    transition: opacity .5 ease;
    stroke: #FDC400;
    stroke-dasharray: 0;
    stroke-width: 1;
    fill: #FEDC66; }
    .graph .chart-circle--item > circle:hover {
      opacity: 1; }
  .graph .chart-rect--item > rect {
    position: relative;
    cursor: pointer;
    opacity: .7;
    -webkit-transition: opacity .5 ease;
    -o-transition: opacity .5 ease;
    transition: opacity .5 ease;
    stroke-linejoin: round;
    fill: #88d3ff;
    stroke: #64B6E7;
    stroke-dasharray: 0;
    stroke-width: 2;
    stroke-linecap: butt; }
    .graph .chart-rect--item > rect:hover {
      opacity: 1; }
  .graph .chart-data {
    -webkit-transition: opacity .25s ease-in;
    -o-transition: opacity .25s ease-in;
    transition: opacity .25s ease-in; }
    .graph .chart-data.graph--triggered {
      opacity: .2;
      -webkit-transition: opacity .25s ease-out;
      -o-transition: opacity .25s ease-out;
      transition: opacity .25s ease-out; }
  .graph .chart-tooltip {
    opacity: 0;
    -webkit-transition: opacity .2s ease;
    -o-transition: opacity .2s ease;
    transition: opacity .2s ease;
    z-index: 1000; }
    .graph .chart-tooltip--shown {
      opacity: 1; }
    .graph .chart-tooltip rect {
      fill: #000000;
      stroke-width: 0; }
    .graph .chart-tooltip text {
      font-size: 12px;
      font-weight: bold;
      fill: #ffffff; }
  .graph-legend {
    padding: 0 1.125rem;
    cursor: pointer; }
    @media (min-width: 640px) {
      .graph-legend {
        padding: 0 2.5rem; } }
    .graph-legend-values {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      background-color: #F7F7F7;
      border: 1px solid #E0E0E0; }
    .graph-legend-headline {
      margin: .5rem 0;
      font-size: 12px;
      font-weight: bold; }
    .graph-legend-value {
      -webkit-box-flex: 1;
          -ms-flex-positive: 1;
              flex-grow: 1;
      -ms-flex-negative: 1;
          flex-shrink: 1;
      width: calc(100% / 12);
      padding: 13px 0 12px;
      font-size: 10px;
      text-align: center;
      border-left: 1px solid #E0E0E0; }
      @media (min-width: 640px) {
        .graph-legend-value {
          font-size: 12px; } }
      .graph-legend-value:nth-child(1) {
        border-left: none; }
    .graph-legend--priceperday .graph-legend-values {
      background-color: #FEDC66;
      border-color: #FDC400; }
    .graph-legend--priceperday .graph-legend-value {
      border-color: #FDC400; }
    .graph-legend--stay .graph-legend-values {
      background-color: #88d3ff;
      border-color: #64B6E7; }
    .graph-legend--stay .graph-legend-value {
      border-color: #64B6E7; }
