html, body { color: #333; font-family: "Roboto", sans-serif; -webkit-font-smoothing: antialiased; height: 100%; width: 100%; }
.container { height: 100%; padding: 0; width: 100%; }

/* Links */
a { transition: background-color .2s, color .2s; }
a:hover,
a:focus { text-decoration: none; }

/* Headers */
h1 { font-size: 3.3em; margin: 30px 0 22px; }
h2 { font-size: 2.2em; margin: 12px 0 0; }
h3 { font-size: 1.8em; margin: 28px 0 0; }
h4 { font-size: 1.6em; margin: 28px 0 0; }
h5 { font-size: 1.4em; margin: 26px 0 0; }
h6 { font-size: 1.3em; margin: 26px 0 0; }

/* Paragraphs & Lists */
p { line-height: 1.5em; margin: 16px 0 6px; }
ul, ol { margin: 16px 0 10px; }
li {  line-height: 1.4em; margin-bottom: 8px; }

/* Forms */
form { margin: 18px 0; }
label { display: block; margin: 10px 0 8px; width: 100%; }
input[type="text"] { margin-bottom: 8px; padding-left: 3px; width: 100%; }
textarea { height: 80px; margin-bottom: 8px; padding: 3px 5px; resize: none; width: 100%; }
input[type="checkbox"],
input[type="radio"] { margin: 0 4px 0 2px; }
input[type="checkbox"] + label,
input[type="radio"] + label { display: inline-block; margin-right: 14px; position: relative; top: -1px; width: auto; }
input[type="submit"],
input[type="reset"] { background-color: #c47; border-radius: 14px; border: 0; color: #fff; letter-spacing: .05em; margin-top: 14px; padding: 4px 16px; transition: background-color .2s; }
.button:hover,
input[type="submit"]:hover,
input[type="reset"]:hover { background-color: #b16; }

/* Map Specific */
#map-area { height: 100%; overflow: hidden; position: relative; width: 100%; }
#map { height: 100%; width: 100%; margin-top: -67px;}

#address-search { background: #fed141; box-shadow: 0 -2px 10px -1px #333; padding: 12px 4%; position: relative; z-index: 1; }
#address-search p { display: inline-block; margin: 0; vertical-align: middle;  width: 46%; }
#address-search p strong { display: block; }
#address-search div { display: inline-block; text-align: right; width: 50%; }
#address-search input { border: 0; display: inline-block; height: 28px; margin: 0; padding: 0 6px; vertical-align: middle; width: 80%; }
#address-search button { background: #fff; border: 0; border-left: 1px solid #aaa;display: inline-block; height: 28px; line-height: 28px; margin: 0; padding: 0 12px; transition: background .2s; vertical-align: middle; }
#address-search button:hover { background: #eee; }
#address-search button span { left: -9999px; position: absolute; }

/* .gm-style .gm-style-iw-c { padding: 0; } */
.gm-style-iw-d { padding: 0 !important; width: 360px; }

#iw-image img { width: 100%; }

#iw-title { background: #000; color: #fff; font-size: 1.6em; padding: 8px 12px; }

#iw-desc { padding: 8px 0; }
#iw-desc p { margin: 4px 0; }
#iw-desc a { border: 1px solid #000;  color: #000; display: block; font-weight: 700; margin: 10px auto 0; padding: 8px; text-align: center; width: 100%; }
#iw-desc a:hover { background-color: #ddd; }
#iw-desc a img { height: 18px; margin-right: 6px; }


.marker {
    color: white;
    /* background-color: #257B68;
    border: solid 1px #257B68; */
    font-weight: 900;
    padding: 4px;
    top: -8px;
    width: max-content;
    font-size: 14px;
    z-index: -400;
    text-shadow: 1px 1px 1px #000;
    letter-spacing: 0.8px;
  }
  
  /* .marker::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translate(-50%, 0%);
    border: solid 8px transparent;
    border-top-color: #257B68;
  } */

/*********************************************/
/****** Media Queries ************************/
/*********************************************/
@media screen and (max-width: 1000px) {
    #address-search { padding: 6px 2%; }
}
 
@media screen and (max-width: 790px) {
    #address-search { font-size: .85em; }
    #address-search p { line-height: 1.3em; }

    .gm-style-iw-d { width: 260px; }
    #iw-title { font-size: 1.1em; font-weight: 700; padding: 5px 8px;}
    #iw-desc { font-size: .85em; }
    #iw-desc a { line-height: 1em; padding: 8px 6px; }
    #iw-desc a img { height: 14px; }
}

@media screen and (max-width: 500px) {
    #address-search p { padding: 0 6px; text-align: center; width: 100%; }
    #address-search div { margin: 8px 0 4px; text-align: center; width: 100%; }
}