/*
	MIXINS
	Meekly forged by Yousemble
	Copyright 2013 Yousemble
*/
.leaflet-control {
  float: none !important;
}

/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
* {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/*
	PRELOADER
	Meekly forged by AirMark
	Copyright 2017 Yousemble
*/
.preloader {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: white;
  z-index: 9999;
}
.preloader .preloader-container {
  position: absolute;
  display: inline-block;
  top: 50%;
  left: 50%;
  margin-top: -120px;
  margin-left: -51px;
  /**/
}
.preloader .spinner {
  width: 20px;
  height: 20px;
  background-color: #111;
  margin: 30px auto;
  -webkit-animation: rotate 1.2s infinite ease-in-out;
  animation: rotate 1.2s infinite ease-in-out;
}
@-webkit-keyframes rotate {
  0% {
    -webkit-transform: perspective(120px);
    background-color: #000;
  }
  50% {
    -webkit-transform: perspective(120px) rotateY(180deg);
    background-color: #000;
  }
  75% {
    background-color: #000;
  }
  100% {
    -webkit-transform: perspective(120px) rotateY(180deg) rotateX(180deg);
    background-color: #000;
  }
}
@keyframes rotate {
  0% {
    transform: perspective(120px) rotateX(0deg) rotateY(0deg);
    -webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg);
  }
  50% {
    transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
    -webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
  }
  100% {
    transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
    -webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
  }
}
.icon {
  position: relative;
  display: inline-block;
  width: 24px;
  height: 24px;
  /**/
}
.icon svg {
  position: absolute;
  top: 2px;
  left: 0;
  fill: currentColor;
  width: 100%;
  height: 100%;
  vertical-align: -0.05em;
  color: #333;
}
.icon.vertical {
  display: block;
  margin: 0 auto 8px auto;
}

.color-picker-swatch,
.color-swatch {
  display: inline-block;
  height: 24px;
  width: 24px;
  cursor: pointer;
}

.color-picker .col-xs-3 {
  padding: 0;
}
.color-picker input[id*="color"] {
  display: none;
}
.color-picker input[id*="color"]:checked + label {
  box-shadow: inset 0 0 0 2px white;
}
.color-picker label[class*="color"] {
  display: inline-block;
  height: 20px;
  width: 20px;
  cursor: pointer;
  border: 1px solid transparent;
  position: relative;
  margin: 8px;
  vertical-align: top;
}
.color-picker label[class*="color"]:hover {
  border-color: #000;
}

.wrapper {
  box-sizing: border-box;
  max-width: 1200px;
  margin: 0 auto;
}

.container-fluid {
  margin-right: auto;
  margin-left: auto;
  padding-right: 2rem;
  padding-left: 2rem;
}

.row {
  box-sizing: border-box;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 0;
  -webkit-flex: 0 1 auto;
  -moz-box-flex: 0;
  -moz-flex: 0 1 auto;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
  -webkit-box-direction: normal;
  -webkit-box-orient: horizontal;
  -webkit-flex-direction: row;
  -moz-flex-direction: row;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.row.gutter {
  margin-right: -0.5rem;
  margin-left: -0.5rem;
}
.row.padding {
  padding-top: 20px;
  padding-bottom: 20px;
}

.row.reverse {
  -webkit-box-direction: reverse;
  -webkit-box-orient: horizontal;
  -webkit-flex-direction: row-reverse;
  -moz-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}

.col.reverse {
  -webkit-box-direction: reverse;
  -webkit-box-orient: vertical;
  -webkit-flex-direction: column-reverse;
  -moz-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
}

[class*="col-xs"] {
  box-sizing: border-box;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -moz-box-flex: 0;
  -moz-flex: 0 0 auto;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  padding-right: 0.5rem;
  padding-left: 0.5rem;
}

.col-xs-1 {
  -webkit-flex-basis: 8.3333333333%;
  -moz-flex-basis: 8.3333333333%;
  -ms-flex-preferred-size: 8.3333333333%;
  flex-basis: 8.3333333333%;
  max-width: 8.3333333333%;
}

.col-xs-2 {
  -webkit-flex-basis: 16.6666666667%;
  -moz-flex-basis: 16.6666666667%;
  -ms-flex-preferred-size: 16.6666666667%;
  flex-basis: 16.6666666667%;
  max-width: 16.6666666667%;
}

.col-xs-3 {
  -webkit-flex-basis: 25%;
  -moz-flex-basis: 25%;
  -ms-flex-preferred-size: 25%;
  flex-basis: 25%;
  max-width: 25%;
}

.col-xs-4 {
  -webkit-flex-basis: 33.3333333333%;
  -moz-flex-basis: 33.3333333333%;
  -ms-flex-preferred-size: 33.3333333333%;
  flex-basis: 33.3333333333%;
  max-width: 33.3333333333%;
}

.col-xs-5 {
  -webkit-flex-basis: 41.6666666667%;
  -moz-flex-basis: 41.6666666667%;
  -ms-flex-preferred-size: 41.6666666667%;
  flex-basis: 41.6666666667%;
  max-width: 41.6666666667%;
}

.col-xs-6 {
  -webkit-flex-basis: 50%;
  -moz-flex-basis: 50%;
  -ms-flex-preferred-size: 50%;
  flex-basis: 50%;
  max-width: 50%;
}

.col-xs-7 {
  -webkit-flex-basis: 58.3333333333%;
  -moz-flex-basis: 58.3333333333%;
  -ms-flex-preferred-size: 58.3333333333%;
  flex-basis: 58.3333333333%;
  max-width: 58.3333333333%;
}

.col-xs-8 {
  -webkit-flex-basis: 66.6666666667%;
  -moz-flex-basis: 66.6666666667%;
  -ms-flex-preferred-size: 66.6666666667%;
  flex-basis: 66.6666666667%;
  max-width: 66.6666666667%;
}

.col-xs-9 {
  -webkit-flex-basis: 75%;
  -moz-flex-basis: 75%;
  -ms-flex-preferred-size: 75%;
  flex-basis: 75%;
  max-width: 75%;
}

.col-xs-10 {
  -webkit-flex-basis: 83.3333333333%;
  -moz-flex-basis: 83.3333333333%;
  -ms-flex-preferred-size: 83.3333333333%;
  flex-basis: 83.3333333333%;
  max-width: 83.3333333333%;
}

.col-xs-11 {
  -webkit-flex-basis: 91.6666666667%;
  -moz-flex-basis: 91.6666666667%;
  -ms-flex-preferred-size: 91.6666666667%;
  flex-basis: 91.6666666667%;
  max-width: 91.6666666667%;
}

.col-xs-12 {
  -webkit-flex-basis: 100%;
  -moz-flex-basis: 100%;
  -ms-flex-preferred-size: 100%;
  flex-basis: 100%;
  max-width: 100%;
}

.col-xs-offset-1 {
  margin-left: 8.3333333333%;
}

.col-xs-offset-2 {
  margin-left: 16.6666666667%;
}

.col-xs-offset-3 {
  margin-left: 25%;
}

.col-xs-offset-4 {
  margin-left: 33.3333333333%;
}

.col-xs-offset-5 {
  margin-left: 41.6666666667%;
}

.col-xs-offset-6 {
  margin-left: 50%;
}

.col-xs-offset-7 {
  margin-left: 58.3333333333%;
}

.col-xs-offset-8 {
  margin-left: 66.6666666667%;
}

.col-xs-offset-9 {
  margin-left: 75%;
}

.col-xs-offset-10 {
  margin-left: 83.3333333333%;
}

.col-xs-offset-11 {
  margin-left: 91.6666666667%;
}

.col-xs-offset-12 {
  margin-left: 100%;
}

.col-xs {
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
  -moz-flex-grow: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  -webkit-flex-basis: 0;
  -moz-flex-basis: 0;
  -ms-flex-preferred-size: 0;
  flex-basis: 0;
  max-width: 100%;
}

.start-xs {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  -moz-justify-content: flex-start;
  justify-content: flex-start;
  text-align: start;
}

.center-xs {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  justify-content: center;
  text-align: center;
}

.end-xs {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  -webkit-justify-content: flex-end;
  -moz-justify-content: flex-end;
  justify-content: flex-end;
  text-align: end;
}

.top-xs {
  -webkit-box-align: start;
  -ms-flex-align: start;
  -webkit-align-items: flex-start;
  -moz-align-items: flex-start;
  align-items: flex-start;
}

.middle-xs {
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  -moz-align-items: center;
  align-items: center;
}

.bottom-xs {
  -webkit-box-align: end;
  -ms-flex-align: end;
  -webkit-align-items: flex-end;
  -moz-align-items: flex-end;
  align-items: flex-end;
}

.around-xs {
  -ms-flex-pack: distribute;
  -webkit-justify-content: space-around;
  -moz-justify-content: space-around;
  justify-content: space-around;
}

.between-xs {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  -moz-justify-content: space-between;
  justify-content: space-between;
}

.first-xs {
  order: -1;
}

.last-xs {
  order: 1;
}

@media only screen and (min-width: 48em) {
  .container {
    width: 46rem;
  }

  [class*="col-sm"] {
    box-sizing: border-box;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 auto;
    -moz-box-flex: 0;
    -moz-flex: 0 0 auto;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }

  .col-sm-1 {
    -webkit-flex-basis: 8.3333333333%;
    -moz-flex-basis: 8.3333333333%;
    -ms-flex-preferred-size: 8.3333333333%;
    flex-basis: 8.3333333333%;
    max-width: 8.3333333333%;
  }

  .col-sm-2 {
    -webkit-flex-basis: 16.6666666667%;
    -moz-flex-basis: 16.6666666667%;
    -ms-flex-preferred-size: 16.6666666667%;
    flex-basis: 16.6666666667%;
    max-width: 16.6666666667%;
  }

  .col-sm-3 {
    -webkit-flex-basis: 25%;
    -moz-flex-basis: 25%;
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    max-width: 25%;
  }

  .col-sm-4 {
    -webkit-flex-basis: 33.3333333333%;
    -moz-flex-basis: 33.3333333333%;
    -ms-flex-preferred-size: 33.3333333333%;
    flex-basis: 33.3333333333%;
    max-width: 33.3333333333%;
  }

  .col-sm-5 {
    -webkit-flex-basis: 41.6666666667%;
    -moz-flex-basis: 41.6666666667%;
    -ms-flex-preferred-size: 41.6666666667%;
    flex-basis: 41.6666666667%;
    max-width: 41.6666666667%;
  }

  .col-sm-6 {
    -webkit-flex-basis: 50%;
    -moz-flex-basis: 50%;
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
  }

  .col-sm-7 {
    -webkit-flex-basis: 58.3333333333%;
    -moz-flex-basis: 58.3333333333%;
    -ms-flex-preferred-size: 58.3333333333%;
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
  }

  .col-sm-8 {
    -webkit-flex-basis: 66.6666666667%;
    -moz-flex-basis: 66.6666666667%;
    -ms-flex-preferred-size: 66.6666666667%;
    flex-basis: 66.6666666667%;
    max-width: 66.6666666667%;
  }

  .col-sm-9 {
    -webkit-flex-basis: 75%;
    -moz-flex-basis: 75%;
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    max-width: 75%;
  }

  .col-sm-10 {
    -webkit-flex-basis: 83.3333333333%;
    -moz-flex-basis: 83.3333333333%;
    -ms-flex-preferred-size: 83.3333333333%;
    flex-basis: 83.3333333333%;
    max-width: 83.3333333333%;
  }

  .col-sm-11 {
    -webkit-flex-basis: 91.6666666667%;
    -moz-flex-basis: 91.6666666667%;
    -ms-flex-preferred-size: 91.6666666667%;
    flex-basis: 91.6666666667%;
    max-width: 91.6666666667%;
  }

  .col-sm-12 {
    -webkit-flex-basis: 100%;
    -moz-flex-basis: 100%;
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }

  .col-sm-offset-1 {
    margin-left: 8.3333333333%;
  }

  .col-sm-offset-2 {
    margin-left: 16.6666666667%;
  }

  .col-sm-offset-3 {
    margin-left: 25%;
  }

  .col-sm-offset-4 {
    margin-left: 33.3333333333%;
  }

  .col-sm-offset-5 {
    margin-left: 41.6666666667%;
  }

  .col-sm-offset-6 {
    margin-left: 50%;
  }

  .col-sm-offset-7 {
    margin-left: 58.3333333333%;
  }

  .col-sm-offset-8 {
    margin-left: 66.6666666667%;
  }

  .col-sm-offset-9 {
    margin-left: 75%;
  }

  .col-sm-offset-10 {
    margin-left: 83.3333333333%;
  }

  .col-sm-offset-11 {
    margin-left: 91.6666666667%;
  }

  .col-sm-offset-12 {
    margin-left: 100%;
  }

  .col-sm {
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
    -moz-flex-grow: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -webkit-flex-basis: 0;
    -moz-flex-basis: 0;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    max-width: 100%;
  }

  .start-sm {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    -webkit-justify-content: flex-start;
    -moz-justify-content: flex-start;
    justify-content: flex-start;
    text-align: start;
  }

  .center-sm {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    justify-content: center;
    text-align: center;
  }

  .end-sm {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    -webkit-justify-content: flex-end;
    -moz-justify-content: flex-end;
    justify-content: flex-end;
    text-align: end;
  }

  .top-sm {
    -webkit-box-align: start;
    -ms-flex-align: start;
    -webkit-align-items: flex-start;
    -moz-align-items: flex-start;
    align-items: flex-start;
  }

  .middle-sm {
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    align-items: center;
  }

  .bottom-sm {
    -webkit-box-align: end;
    -ms-flex-align: end;
    -webkit-align-items: flex-end;
    -moz-align-items: flex-end;
    align-items: flex-end;
  }

  .around-sm {
    -ms-flex-pack: distribute;
    -webkit-justify-content: space-around;
    -moz-justify-content: space-around;
    justify-content: space-around;
  }

  .between-sm {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
  }

  .first-sm {
    order: -1;
  }

  .last-sm {
    order: 1;
  }
}
@media only screen and (min-width: 62em) {
  .container {
    width: 61rem;
  }

  [class*="col-md"] {
    box-sizing: border-box;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 auto;
    -moz-box-flex: 0;
    -moz-flex: 0 0 auto;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }

  .col-md-1 {
    -webkit-flex-basis: 8.3333333333%;
    -moz-flex-basis: 8.3333333333%;
    -ms-flex-preferred-size: 8.3333333333%;
    flex-basis: 8.3333333333%;
    max-width: 8.3333333333%;
  }

  .col-md-2 {
    -webkit-flex-basis: 16.6666666667%;
    -moz-flex-basis: 16.6666666667%;
    -ms-flex-preferred-size: 16.6666666667%;
    flex-basis: 16.6666666667%;
    max-width: 16.6666666667%;
  }

  .col-md-3 {
    -webkit-flex-basis: 25%;
    -moz-flex-basis: 25%;
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    max-width: 25%;
  }

  .col-md-4 {
    -webkit-flex-basis: 33.3333333333%;
    -moz-flex-basis: 33.3333333333%;
    -ms-flex-preferred-size: 33.3333333333%;
    flex-basis: 33.3333333333%;
    max-width: 33.3333333333%;
  }

  .col-md-5 {
    -webkit-flex-basis: 41.6666666667%;
    -moz-flex-basis: 41.6666666667%;
    -ms-flex-preferred-size: 41.6666666667%;
    flex-basis: 41.6666666667%;
    max-width: 41.6666666667%;
  }

  .col-md-6 {
    -webkit-flex-basis: 50%;
    -moz-flex-basis: 50%;
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
  }

  .col-md-7 {
    -webkit-flex-basis: 58.3333333333%;
    -moz-flex-basis: 58.3333333333%;
    -ms-flex-preferred-size: 58.3333333333%;
    flex-basis: 58.3333333333%;
    max-width: 58.3333333333%;
  }

  .col-md-8 {
    -webkit-flex-basis: 66.6666666667%;
    -moz-flex-basis: 66.6666666667%;
    -ms-flex-preferred-size: 66.6666666667%;
    flex-basis: 66.6666666667%;
    max-width: 66.6666666667%;
  }

  .col-md-9 {
    -webkit-flex-basis: 75%;
    -moz-flex-basis: 75%;
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    max-width: 75%;
  }

  .col-md-10 {
    -webkit-flex-basis: 83.3333333333%;
    -moz-flex-basis: 83.3333333333%;
    -ms-flex-preferred-size: 83.3333333333%;
    flex-basis: 83.3333333333%;
    max-width: 83.3333333333%;
  }

  .col-md-11 {
    -webkit-flex-basis: 91.6666666667%;
    -moz-flex-basis: 91.6666666667%;
    -ms-flex-preferred-size: 91.6666666667%;
    flex-basis: 91.6666666667%;
    max-width: 91.6666666667%;
  }

  .col-md-12 {
    -webkit-flex-basis: 100%;
    -moz-flex-basis: 100%;
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }

  .col-md-offset-1 {
    margin-left: 8.3333333333%;
  }

  .col-md-offset-2 {
    margin-left: 16.6666666667%;
  }

  .col-md-offset-3 {
    margin-left: 25%;
  }

  .col-md-offset-4 {
    margin-left: 33.3333333333%;
  }

  .col-md-offset-5 {
    margin-left: 41.6666666667%;
  }

  .col-md-offset-6 {
    margin-left: 50%;
  }

  .col-md-offset-7 {
    margin-left: 58.3333333333%;
  }

  .col-md-offset-8 {
    margin-left: 66.6666666667%;
  }

  .col-md-offset-9 {
    margin-left: 75%;
  }

  .col-md-offset-10 {
    margin-left: 83.3333333333%;
  }

  .col-md-offset-11 {
    margin-left: 91.6666666667%;
  }

  .col-md-offset-12 {
    margin-left: 100%;
  }

  .col-md {
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
    -moz-flex-grow: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -webkit-flex-basis: 0;
    -moz-flex-basis: 0;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    max-width: 100%;
  }

  .start-md {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    -webkit-justify-content: flex-start;
    -moz-justify-content: flex-start;
    justify-content: flex-start;
    text-align: start;
  }

  .center-md {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    justify-content: center;
    text-align: center;
  }

  .end-md {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    -webkit-justify-content: flex-end;
    -moz-justify-content: flex-end;
    justify-content: flex-end;
    text-align: end;
  }

  .top-md {
    -webkit-box-align: start;
    -ms-flex-align: start;
    -webkit-align-items: flex-start;
    -moz-align-items: flex-start;
    align-items: flex-start;
  }

  .middle-md {
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    align-items: center;
  }

  .bottom-md {
    -webkit-box-align: end;
    -ms-flex-align: end;
    -webkit-align-items: flex-end;
    -moz-align-items: flex-end;
    align-items: flex-end;
  }

  .around-md {
    -ms-flex-pack: distribute;
    -webkit-justify-content: space-around;
    -moz-justify-content: space-around;
    justify-content: space-around;
  }

  .between-md {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
  }

  .first-md {
    order: -1;
  }

  .last-md {
    order: 1;
  }
}
/*
  :: Global
------------------------------------------------ */
.hide {
  display: none !important;
}

.show {
  display: block !important;
}

.ar {
  text-align: right;
}

.ac {
  text-align: center;
}

.container {
  max-width: 640px;
  margin: auto auto;
  margin-top: 40px;
  margin-bottom: 60px;
  padding: 30px;
  background-color: #fff;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23);
}

@media only screen and (max-width: 480px) {
  .container {
    margin: 0;
    padding: 20px;
  }
}
.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

hr {
  border-top: 1px solid rgba(0, 0, 0, 0.075);
  border-bottom: none;
  margin-top: 30px;
  margin-bottom: 30px;
}

.logo-mapstack {
  width: 50px;
  height: 50px;
}

.project-title {
  display: block;
  font-weight: bold;
  border-bottom: 1px solid rgba(0, 0, 0, 0.075);
  line-height: 0;
  margin-bottom: 15px;
  margin-top: 30px;
}

.project-title span {
  background: #fff;
  padding-right: 15px;
}

a, a:visited {
  color: #333;
}

b {
  font-weight: 600;
}

html {
  font-size: 1em;
}

body {
  background-color: white;
  font-family: 'Roboto', sans-serif;
  font-weight: 400;
  line-height: 1.45;
  color: #333;
}

h1, h2, h3, h4 {
  margin-bottom: 0.25em;
  font-weight: inherit;
  line-height: 1.2;
}

h1 {
  margin-top: 0;
  font-size: 3.157em;
}

h2 {
  font-size: 2.369em;
}

h3 {
  font-size: 1.777em;
}

h4 {
  font-size: 1.333em;
}

small, .font_small {
  font-size: 0.75em;
}

.btn {
  display: block;
  position: relative;
  padding: 20px;
  text-align: center;
  text-decoration: none;
  /**/
}
.btn.btn-header {
  height: 60px;
  line-height: 15px;
}
.btn:hover {
  cursor: pointer;
  background-color: rgba(0, 0, 0, 0.1);
}
.btn.general {
  display: inline-block;
  border: 1px solid black;
  padding: 15px 30px;
}
.btn.general:hover {
  color: white;
  background-color: black;
}

.btn-group {
  position: relative;
  display: inline-block;
}
.btn-group .btn-dropdown {
  display: none;
  position: absolute;
  top: 100%;
  right: 0;
  z-index: 1000;
  min-width: 156px;
  padding: 5px;
  margin: 2px 0 0;
  font-size: 14px;
  text-align: left;
  list-style: none;
  background-color: #fff;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 4px;
  -webkit-box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.175);
}

.btn-inline {
  display: inline-block;
  vertical-align: top;
  width: 24px;
  height: 24px;
  line-height: 0;
  padding: 10px;
  cursor: pointer;
  margin: 8px;
  /**/
}
.btn-inline:hover {
  opacity: 0.5;
}
.btn-inline svg {
  top: 0;
}

/*
	FORMS
	Meekly forged by Yousemble
	Copyright 2016 Yousemble
*/
label, input, button, select, textarea {
  line-height: 24px;
  font-size: 14px;
}

label {
  display: block;
  margin-top: 15px;
  margin-bottom: 5px;
  letter-spacing: 0.5px;
}
label .inline {
  display: inline-block;
}

select, textarea, input:not([type="radio"]):not([type="checkbox"]) {
  display: inline-block;
  width: 100%;
  height: 40px;
  line-height: 24px;
  padding: 7px 8px;
  vertical-align: middle;
  box-sizing: border-box;
  background-color: white;
  border: 1px solid #e3e3e3;
  -webkit-transition: border linear 0.2s, box-shadow linear 0.2s;
  -moz-transition: border linear 0.2s, box-shadow linear 0.2s;
  -o-transition: border linear 0.2s, box-shadow linear 0.2s;
  transition: border linear 0.2s, box-shadow linear 0.2s;
}
select:focus, textarea:focus, input:not([type="radio"]):not([type="checkbox"]):focus {
  border-color: #aaa;
  outline: 0;
}

input, textarea {
  min-width: 220px;
}

textarea {
  height: auto;
}

/*
  :: TOGGLE

	<input class="toggle" id="hideDrawLayer" type="checkbox" checked />
	<label class="toggle-btn" for="hideDrawLayer"></label>

------------------------------------------------ */
.toggle {
  display: none;
}
.toggle + .toggle-btn {
  position: relative;
  outline: 0;
  display: none;
  width: 40px;
  height: 22px;
  cursor: pointer;
  user-select: none;
  background: #d4d3d3;
  border-radius: 2em;
  padding: 2px;
  transition: all .4s ease;
  /* Reset default form styling */
  margin: 0;
  letter-spacing: 0;
}
.toggle + .toggle-btn:after, .toggle + .toggle-btn:before {
  position: relative;
  display: block;
  content: "";
  width: 50%;
  height: 100%;
}
.toggle + .toggle-btn:after {
  left: 0;
  border-radius: 50%;
  background: #fff;
  transition: all .2s ease;
}
.toggle + .toggle-btn:before {
  display: none;
}
.toggle:checked + .toggle-btn:after {
  left: 50%;
}
.toggle:checked + .toggle-btn {
  background: #aaa;
}

/*
  :: SELECT

  <div class="select">
    <select>
      <option>Please Select</option>
      <option>Option</option>
      <option>Option</option>
    </select>
  </div>

------------------------------------------------ */
/* Base elements */
.select {
  position: relative;
  display: inline-block;
  width: 100%;
}

/* SELECT - Normal State */
.select select {
  display: inline-block;
  width: 100%;
  padding: 10px 15px;
  line-height: 15px;
  cursor: pointer;
  border: 0;
  border-radius: 0;
  outline: 0;
  border: 1px solid #e3e3e3;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

/* SELECT - Hover */
.select select:hover,
.select select:focus {
  color: #000;
  background: rgba(0, 0, 0, 0.01);
}

/* SELECT - Arrow */
.select:before {
  content: '';
  position: absolute;
  top: 15px;
  right: 15px;
  width: 0;
  height: 0;
  pointer-events: none;
  border-width: 8px 5px 0 5px;
  border-style: solid;
  border-color: #333 transparent transparent transparent;
  z-index: 1;
}

/* SELECT - Disabled */
.select select:disabled {
  pointer-events: none;
  opacity: .5;
}

.map-container {
  width: 100%;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

/* Map Details - Controls */
.map-details {
  margin-left: 10px;
  margin-top: 10px;
  padding-left: 10px;
  /* Correct Leaflet Styling */
}
.map-details p {
  min-height: 20px;
  line-height: 20px;
}

/*
  :: Logo
------------------------------------------------ */
.logo-container {
  width: 80%;
  text-align: center;
  margin: 0 auto;
  /*border: 1px solid red;*/
}

.logo-icon {
  display: inline-block;
  margin: 0 auto;
  width: 50px;
  /* SVG by by Madebyoliver - http://www.flaticon.com/free-icon/layers_149243#term=layer&page=1&position=2 */
}

.logo {
  font-family: 'Montserrat', sans-serif;
  text-transform: uppercase;
}

/*
  :: Poly Line Verticies
------------------------------------------------ */
.leaflet-icon,
.leaflet-editing-icon {
  border: none;
  border-radius: 50%;
  width: 16px !important;
  height: 16px !important;
  margin-left: -8px !important;
  margin-top: -8px !important;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}

.leaflet-icon:hover:before,
.leaflet-editing-icon:hover:before {
  position: absolute;
  content: '';
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background-color: #999;
  z-index: 5;
  top: 50%;
  left: 50%;
  margin-top: -2px;
  margin-left: -2px;
}

/*
#export {
  position: absolute;
  top:50px;
  right:10px;
  z-index:9999;
  cursor: pointer;
  font-size:12px;
  text-decoration:none;
}
#export {
  top:90px;
}*/
/*
  :: Leaflet control (ui elements)
------------------------------------------------ */
.leaflet-control-container .leaflet-top.leaflet-right {
  /*placing zoom and scale bar inline*/
  display: inline-flex !important;
}

/*
  :: Legend
------------------------------------------------ */
.dsm-legend {
  display: block;
  line-height: 20px;
  padding-right: 10px;
  padding-left: 10px;
  /* Correct Leaflet Styling */
}

.dsm-legend i {
  width: 20px;
  height: 20px;
  float: left;
  margin-right: 8px;
  /*opacity: 0.7;*/
}

.RdYlGn_11-legend {
  display: block;
  line-height: 20px;
  padding-right: 10px;
  padding-left: 10px;
  /* Correct Leaflet Styling */
}

.RdYlGn_11-legend i {
  width: 20px;
  height: 20px;
  float: left;
  margin-right: 8px;
}

.spectral_11-legend {
  display: block;
  line-height: 20px;
  padding-right: 10px;
  padding-left: 10px;
  /* Correct Leaflet Styling */
}

.spectral_11-legend i {
  width: 20px;
  height: 20px;
  float: left;
  margin-right: 8px;
}

/*
 :: MARKER POPUPS
 -----------------------------------------------*/
.leaflet-popup-content {
  width: auto !important;
  padding-top: 8px;
  min-width: 140px;
  text-align: center;
}

.groundtruth-img {
  width: 500px;
}

.ground-truth-coordinates {
  text-align: center;
}

@media only screen and (max-width: 600px) {
  .groundtruth-img {
    width: 300px;
  }
}
/*
 :: Custom Icon
 -----------------------------------------------*/
.camera-container {
  display: block;
  position: absolute;
  /*border: 1px solid green;*/
}

.marker-icon {
  position: absolute;
  left: -12px;
  top: -40px;
  z-index: 999;
}

.marker-icon:hover + .camera-direction {
  display: block;
}

.camera-direction {
  display: none;
  position: relative;
  width: 100px;
  height: 100px;
  /*border-top: 2px solid rgba(0,0,0,.5);
  border-left: 2px solid rgba(0,0,0,.5);*/
  /**/
  /*border-width: 2px;
   border-style: solid;
   -webkit-border-image:
     -webkit-radial-gradient(black, rgba(0, 0, 0, 0)) 1 100%;
   border-image:
     radial-gradient(to bottom, black, rgba(0, 0, 0, 0)) 1 100%;
  */
  /**/
  -ms-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transform: rotate(0deg);
  -ms-transform-origin: 0% 0%;
  -webkit-transform-origin: 0% 0%;
  transform-origin: 0% 0%;
  overflow: hidden;
}

.camera-direction:hover {
  pointer-events: none;
}

.shader {
  display: block;
  position: absolute;
  left: -100px;
  top: -100px;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  background: -webkit-radial-gradient(rgba(255, 255, 255, 0.7), rgba(255, 255, 255, 0.1));
  background: -o-radial-gradient(rgba(255, 255, 255, 0.7), rgba(255, 255, 255, 0.1));
  background: -moz-radial-gradient(rgba(255, 255, 255, 0.7), rgba(255, 255, 255, 0.1));
  background: radial-gradient(rgba(255, 255, 255, 0.7), rgba(255, 255, 255, 0.1));
}

.shader:hover {
  pointer-events: none;
}

/*
	PANELS
	Meekly forged by AirMark
	Copyright 2017 Yousemble
*/
.panel {
  position: absolute;
  top: 60px;
  width: 100%;
  bottom: 0;
  padding: 10px;
  overflow-y: auto;
  /**/
}
.panel.draw {
  display: block;
  z-index: 999;
  background-color: #fff;
  box-sizing: border-box;
}
.panel section {
  display: block;
  padding: 10px 0 10px 0;
  margin-bottom: 10px;
  /**/
  border-bottom: 1px solid rgba(0, 0, 0, 0.12);
}
.panel section .section-title {
  color: rgba(0, 0, 0, 0.87);
  font-size: 16px;
  margin-bottom: 15px;
  font-weight: 500;
}
.panel section .section-title p {
  font-weight: normal;
}
.panel section:last-child {
  border: none;
}

/*
	NAV
	Meekly forged by AirMark
	Copyright 2017 Yousemble
*/
.side-nav {
  /*height: 100%;*/
  min-height: 100%;
  width: 25%;
  position: absolute;
  right: 80%;
  bottom: 0;
  left: 0;
  z-index: 999;
  background-color: white;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23);
  -webkit-transition-duration: 0.3s;
  -moz-transition-duration: 0.3s;
  -o-transition-duration: 0.3s;
  transition-duration: 0.3s;
  /**/
}
.side-nav header {
  position: relative;
  display: block;
  height: 60px;
  /**/
}
.side-nav.closed {
  left: -25%;
}
.side-nav.closed .nav-slide-btn .btn-arrow.right {
  display: block;
}
.side-nav.closed .nav-slide-btn .btn-arrow.left {
  display: none;
}
.side-nav .nav-slide-btn {
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 999;
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  width: 20px;
  height: 60px;
  background-color: white;
  cursor: pointer;
  outline: none;
  border: 0;
  padding: 0;
  margin: 0;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16), 0 3px 6px rgba(0, 0, 0, 0.23);
  clip: rect(-3px, 26px, 66px, 0px);
}
.side-nav .nav-slide-btn .btn-arrow.left {
  left: -1px;
  top: 25px;
}
.side-nav .nav-slide-btn .btn-arrow.right {
  display: none;
  left: -5px;
  top: 25px;
}
.side-nav .layer-control-container {
  position: relative;
  display: inline-block;
  margin-bottom: 5px;
  padding: 5px 0;
  width: 100%;
  /**/
}
.side-nav .layer-control-container input {
  min-width: auto;
}
.side-nav .layer-control-container label {
  margin: 0;
  display: inline-block;
  padding-right: 15px;
  cursor: pointer;
  /**/
}
.side-nav .layer-control-panel {
  display: none;
  width: 100%;
  height: 175px;
  padding: 10px 25px;
  box-sizing: border-box;
}
.side-nav .layer-control-panel .subtitle {
  font-weight: 500;
  margin-bottom: 5px;
}
.side-nav .layer-control-panel .short-description {
  font-size: 14px;
  margin-bottom: 10px;
}
.side-nav .layer-control-panel .description {
  font-size: 14px;
  color: #888;
}

@media only screen and (max-width: 1024px) {
  .side-nav {
    width: 320px;
  }
  .side-nav.closed {
    left: -320px;
  }
}
.btn-accordion.expand, .btn-accordion.contract {
  position: absolute;
  top: 5px;
  right: 0;
  width: 24px;
  height: 24px;
  cursor: pointer;
}
.btn-accordion.expand:before, .btn-accordion.expand:after, .btn-accordion.contract:before, .btn-accordion.contract:after {
  position: absolute;
  content: '';
  transform: translate(-50%, -50%);
  background: #000;
  top: 50%;
  left: 50%;
}
.btn-accordion.expand:hover:before, .btn-accordion.expand:hover:after, .btn-accordion.contract:hover:before, .btn-accordion.contract:hover:after {
  background: #555;
  transition: 0.2s;
}
.btn-accordion.expand:after, .btn-accordion.contract:after {
  width: 10px;
  height: 2px;
}
.btn-accordion.expand:before {
  height: 10px;
  width: 2px;
}

#measurement {
  display: none;
}

#view_groundtruthing {
  display: none;
}

.groundtruth_img {
  width: 100%;
}

/*
	ARROWS
	Meekly forged by AirMark
	Copyright 2017 Yousemble
*/
.arrow, .btn-arrow {
  position: relative;
  display: inline-block;
  width: 14px;
  height: 14px;
  -webkit-transition: all 0.5s cubic-bezier(0.645, 0.045, 0.355, 1);
  -moz-transition: all 0.5s cubic-bezier(0.645, 0.045, 0.355, 1);
  -o-transition: all 0.5s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: all 0.5s cubic-bezier(0.645, 0.045, 0.355, 1);
  cursor: pointer;
  /**/
}
.arrow:before, .btn-arrow:before {
  position: absolute;
  content: '';
  width: 8px;
  height: 8px;
  border-top: 2px solid rgba(0, 0, 0, 0.9);
  border-left: 2px solid rgba(0, 0, 0, 0.9);
}
.arrow.top:before, .btn-arrow.top:before {
  transform: rotate(45deg);
}
.arrow.right:before, .btn-arrow.right:before {
  transform: rotate(135deg);
}
.arrow.bottom:before, .btn-arrow.bottom:before {
  transform: rotate(-135deg);
}
.arrow.left:before, .btn-arrow.left:before {
  transform: rotate(-45deg);
}

.btn-arrow {
  position: absolute;
  right: 0;
}
