.font-weight-bold {
    font-weight: bold !important;
}

@font-face {
    font-family: Figtree;
    src: url(../fonts/Figtree-Regular.ttf) format("truetype");
}

@font-face {
    font-family: Figtree;
    font-weight: bold;
    src: url(../fonts/Figtree-Bold.ttf) format("truetype");
}

@font-face {
    font-family: Figtree;
    font-weight: normal;
    font-style: italic;
    src: url(../fonts/Figtree-Italic.ttf) format("truetype");
}

@font-face {
    font-family: 'Charter ITC TT';
    font-style: normal;
    font-weight: normal;
    src: local('Charter ITC TT'), url('../fonts/charter-itc-tt-587bd77031c7e.woff') format('woff');
}


@font-face {
    font-family: 'Charter ITC TT Italic';
    font-style: normal;
    font-weight: normal;
    src: local('Charter ITC TT Italic'), url('../fonts/charter-itc-tt-italic-587bd78ad37ea.woff') format('woff');
}


@font-face {
    font-family: 'Charter SC ITC TT';
    font-style: normal;
    font-weight: normal;
    src: local('Charter SC ITC TT'), url('../fonts/charter-sc-itc-tt-587bd7e5e3f51.woff') format('woff');
}

html,
body {
    font-family: 'Figtree';
}

a {
    color: #1588e2;
}

.site-container {
    display: flex;
    flex-direction: column;
    height: 100vh;
}

.site-container .site-top-logo-and-content {
    flex-grow: 1;
    flex-shrink: 1;
}

.site-container .site-bottom-footer {
    flex-grow: 0;
    flex-shrink: 0;
}

.header {
    height: 72px;
    background-color: #fff;
    -webkit-box-shadow: 0px 0px 4px 0px rgba(221,224,225,1);
    -moz-box-shadow: 0px 0px 4px 0px rgba(221,224,225,1);
    box-shadow: 0px 0px 4px 0px rgba(221,224,225,1);
}

.header .header-container {
    position: relative;
    margin: 0 auto !important;
    padding: 0 60px;
    text-align: center;
}

@media (max-width: 576px) {
    .header .header-container {
        padding: 0 30px;
    }
}

@media (max-width:992px) {
    .header {
        height: 60px;
    }
    .header .header-container {
        text-align: left;
    }

    .header .logo {
        padding-top: 8px !important;
        margin-left: 20px !important;
    }

    .header .logo img {
        width: 32px !important;
        height: 35px !important;
    }
}

.header .logo {
    display: flex;
    padding-top: 11px;
    font-family: Arial, Helvetica, sans-serif;
    color: #48b9e8;
    letter-spacing: 1px;
    margin-left: 15px;
    font-weight: 200;
}

.header .logo img {
    margin-right: 5px;
    margin-top: 3px;
    width: 32px;
    height: 35px;
}

.header .logo-first {
    font-size: 24px;
    line-height: 45px;
}

.header .logo-second {
    font-size: 24px;
    line-height: 45px;
}

.header .logo:hover {
    text-decoration: none;
    color: #48b9e8;
}

.header .logo img,
.header .logo .embossed,
.header .logo .regular {
    display: inline-block;
    vertical-align: middle;
}

.header .logo .embossed {
    font-weight: bold;
    margin-left: 7px;
}

.header .header-container .search {
    display: none;
    position: absolute;
    top: 19px;
    right: calc(30px + 15px);
    height: 34px;
    #border: 1px solid #dedede;
    border-radius: 5px;
    color: #a1a3a5;
    background-image: url('/static/images/search-icon.png');
    background-repeat: no-repeat;
    background-position: 10px 7px;
    padding-left: 36px;
    font-size: 14px;
    line-height: 34px;
    #width: 270px;

    width: 35px !important;
    border: 1px solid transparent;
}

.header .header-container .search:focus {
    outline: none;
}

.header .header-container .search.active {
    width: 270px !important;
    border: 1px solid #dedede;
}

@media (max-width:1400px) {
    .header .header-container .search {
        width: 35px !important;
        border: 1px solid transparent;
    }
}

@media (min-width:768px) {
    .header .header-container .search {
        display: block;
    }

    .header .header-container {
        text-align: left;
    }
}

.content {
    background-color: #fff;
    margin-top: 20px;
    padding: 30px;
    margin-bottom: 30px;
}

.content-nomargin {
    padding-top: 0;
    padding-bottom: 0;
}

@media (max-width:992px) {
    .content {
        padding: 15px;
        margin-bottom: 15px;
    }
}

.blog-post-item {
    margin: 15px 0;
    padding: 0 0 15px 0;
    clear: both;
}

.blog-post-item:first-child {
    margin-top: 0;
}

.blog-post-item:last-child {
    border: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.blog-post-item:last-child .listing-view-hr {
    display: none;
}

.blog-post-item:last-child .listing-view-without-image {
    border-bottom: none;
}

.blog-post .blog-post-link,
.blog-post .blog-post-link:hover,
.blog-post .blog-post-link h1 {
    color: #000;
    text-decoration: none;
    font-family: 'Figtree';
    font-weight: bold;
    font-style: normal;
    font-size: 48px;
}

@media (max-width:992px) {
    .blog-post .blog-post-link h1 {
        font-size: 28px;
        margin-top: 0 !important;
    }
}

.blog-post .blog-post-link h2 {
    font-weight: bold;
}

.blog-post .blog-post-link h4 {
    font-weight: bold;
}

.blog-post .blog-post-description {
    font-family: 'Figtree';
    font-weight: normal;
    font-style: normal;
    font-size: 16px;
}

/* embed yt videos */
.blog-post div iframe {
    width: 780px;
    height: 440px;
    max-width: 100%;
}

.blog-post blockquote {
    margin-left: 0;
    padding: 20px 0 20px 40px;
    border-left: 4px solid #ffa41c;
    font-weight: bold;
}

@media (max-width:992px) {
    .blog-post .blog-post-description {
        font-size: 14px;
    }

    .blog-post div iframe {
        height: 190px;
    }
}


.blog-post .blog-meta {
    border-top: 1px solid #d1d1d3;
    border-bottom: 1px solid #d1d1d3;
    padding-top: 15px;
    padding-bottom: 15px;
    box-sizing: content-box;
    color: #c0c0c1;
    font-family: 'Figtree';
    margin-bottom: 30px;
}

.blog-post .blog-meta .blog-meta-avatar {
    display: inline-block;
    width: 40px;
    height: 40px;
    vertical-align: middle;
}

.blog-post .blog-meta .blog-meta-avatar img {
    border-radius: 100%;
    width: 40px;
    height: 40px;
}


.blog-post .blog-meta .blog-meta-content {
    display: inline-block;
    vertical-align: middle;
    margin-left: 15px;
}

.blog-post .blog-post-image-container {
    text-align: center;
    margin-bottom: 45px;
}

.blog-post .blog-post-image-container .blog-post-image img {
    width: auto !important;
    height: auto !important;
}

.blog-post .blog-post-image {
    display: inline-block;
    margin: 0 auto;
    position: relative;
}

.blog-post .blog-body {
    color: #464646;
    font-family: 'Charter ITC TT';
    font-size: 18px;
}

.blog-post .blog-post-image img,
.blog-post .blog-body img {
    max-width: 100%;
}

.annotated-image img {
    margin: 0 !important;
}

.annotated-image .license .license-text {
    color: #9c9c9c;
    font-size: 14px;
}

.annotated-image .license .license-html {
    display: none;
}

.annotated-image .caption {
    font-weight: bold;
}

.blog-post .blog-post-image img.full-width,
.blog-post .blog-body img.full-width {
    width: 100%;
    height: auto;
}

.blog-post .blog-post-image .annotated-image.left,
.blog-post .blog-body .annotated-image.left {
    max-width: 500px;
    margin: 0 30px 30px 0;
}

.review-item .annotated-image {
    width: 100% !important;
    max-width: 100% !important;;
}

.blog-post .blog-post-image .annotated-image.right,
.blog-post .blog-body .annotated-image.right {
    max-width: 500px;
    float: right;
    margin: 0 0 30px 30px;
}

.richtext-image {
    margin: 30px auto;
    text-align: center;
    display: block;
}

.blog-post .blog-post-image .blog-post-image-license {
    position: absolute;
    bottom: 20px;
    right: 30px;
    color: #fff;
    background-color: #10181f;
    border-radius: 5px;
    padding: 4px 8px;
    font-size: 14px;
}

.blog-post .blog-body h1,
.blog-post .blog-body h2,
.blog-post .blog-body h3,
.blog-post .blog-body h4,
.blog-post .blog-body h5,
.blog-post .blog-body h6 {
    color: #000;
    font-family: 'Figtree';
    font-weight: bold;
}

.blog-post .blog-body h2 {
    font-size: 28px;
    margin-top: 50px;
    margin-bottom: 15px;
}

.blog-post .blog-body h2.no-margin {
    margin-top: 0;
}

.blog-post .blog-body h3 {
    font-size: 20px;
    margin-bottom: 15px;
}

.blog-post .blog-meta.blog-meta-in-this-post {
    margin-top: 10px;
    padding-top: 45px;
    padding-bottom: 45px;
    margin-bottom: 10px;
    color: #a7a8a9;
    font-size: 18px;
    border: none;
}

.blog-post .blog-meta.blog-meta-in-this-post .in-this-post {
    color: #3c3d3d;
}

.blog-post .blog-meta.blog-meta-in-this-post a {
    color: #a7a8a9;
}

.blog-post .meta.date {
    color: #505050;
    margin-top: -5px;
    margin-bottom: 15px;
}

.blog-post .blog-intro {
    font-family: 'Charter ITC TT';
    font-size: 18px;
    color: #7a7577;
}

#latest-updates .latest-updates-header {
    text-align: center;
}

#latest-updates.with-margin {
    margin-top: 50px;
    margin-bottom: 50px;
}

#latest-updates a, #latest-updates a:hover {
    text-decoration: none;
    color: inherit;
}

#latest-updates .latest-updates-header span {
    text-transform: uppercase;
    color: #464646;
}

#latest-updates .latest-updates-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

#latest-updates .latest-updates-container .latest-updates-post {
    flex-basis: 48%;
    margin-top: 20px;
}

#latest-updates .latest-updates-container.latest-updates-container-3 .latest-updates-post {
    flex-basis: 32%;
    margin-top: 20px;
}

@media screen and (max-width: 768px) {
    #latest-updates .latest-updates-container .latest-updates-post {
        flex-basis: 100% !important;
    }
}

#latest-updates .latest-updates-container .latest-updates-post .latest-updates-post-image {
    display: inline-block;
    margin-bottom: 1rem;
    width: 100%;
}

#latest-updates .latest-updates-container .latest-updates-post .latest-updates-post-image img {
    width: 100%;
    max-width: 100%;
    height: auto;
    border: 1px solid #d9d9d9;
}

#latest-updates .latest-updates-container .latest-updates-post .latest-updates-post-title {
    font-size: 20px;
    margin-bottom: 7px;
}

#latest-updates .latest-updates-container .latest-updates-post .latest-updates-post-date {
    font-size: 14px;
}

#latest-updates .latest-updates-container .latest-updates-post .latest-updates-post-date,
#latest-updates .latest-updates-container .latest-updates-post .latest-updates-post-intro {
    color: #505050;
    margin-top: -5px;
    margin-bottom: 15px;
}

.service-provider-page .blog-post .blog-post-link h1,
.service-provider-page .blog-post .blog-body h1 {
    font-size: 26px;
    margin-top: 65px;
}

.water-provider-page .blog-post .blog-body h2 {
    font-size: 18px;
    margin-top: 15px;
}

.service-provider-page .blog-post .blog-body a {
    text-decoration: none;
    /*color: #505050;*/
}

.more-from-site {
    position: relative;
    margin-top: 45px;
}

.more-from-site .more-link {
    position: absolute;
    top: 0;
    right: 0;
    white-space: nowrap;
}

.more-from-site h1 {
    font-size: 18px;
    font-weight: bold;
    margin-top: -20px;
    width: 80%;
}

.more-from-site a {
    width: 32%;
    display: inline-block;
    color: #464646;
    text-decoration: none;
}

.more-from-site a:hover {
    text-decoration: underline;
}

.page-cover-image {
    margin-left: -30px;
    margin-right: -30px;
    margin-top: -40px;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    padding-left: 65px;
    padding-bottom: 18px;

    background: #4f5d78; /* Old browsers */
    background: -moz-linear-gradient(top, #4f5d78 0%, #0f2e46 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(top, #4f5d78 0%,#0f2e46 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to bottom, #4f5d78 0%,#0f2e46 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4f5d78', endColorstr='#0f2e46',GradientType=0 ); /* IE6-9 */
    position: relative;
}

.page-cover-image .page-cover-image-title-link {
    display: block;
    font-weight: bold;
    color: #fff;
    text-decoration: none;
    font-size: 34px;
    padding-top: 60px;
}

.page-cover-image .page-cover-image-subtitle {
    color: #fff;
    font-size: 18px;
    margin-top: -6px;
    font-weight: bold;

}

.page-cover-image .page-cover-image-license {
    position: absolute;
    bottom: 20px;
    right: 30px;
    color: #fff;
    background-color: rgba(0, 0, 0, 0.75);
    border-radius: 5px;
    padding: 4px 8px;
    font-size: 14px;
}

.what-can-we-help-you-with {
    color: #fff;
    margin-top: 50px;
    font-weight: bold;
    font-size: 18px;
    margin-bottom: 15px;
}


.water-provider-page-button {
    background-color: #10181f;
    color: #fff;
    border-radius: 5px;
    font-size: 16px;
    font-weight: bold;
    display: inline-block;
    line-height: 58px;
    padding: 0 22px;
    width: 360px;
    margin-right: 20px;
    margin-bottom: 15px;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

.water-provider-page-button:hover {
    color: #5c8ab2;
    text-decoration: none;
}

.icon-water-quality,
.icon-customer-service,
.icon-start-stop-service,
.icon-pay-bill {
    display: inline-block;
    height: 31px;
    vertical-align: middle;
    margin-right: 20px;
    width: 30px;
}

.icon-water-quality {
    background: url('../images/water-quality-icon.png');
    margin-right: 28px;
}

.icon-start-stop-service {
    background: url('../images/start-stop-service-icon.png');
}

.icon-customer-service {
    background: url('../images/customer-service-icon.png');
    width: 38px;
}

.icon-pay-bill {
    background: url('../images/pay-bill-icon.png');
    width: 23px;
    margin-right: 27px;
}

.listing-view-without-image {
    border-bottom: 1px solid #dedede;
    padding-bottom: 25px;
}

.listing-view-with-image {
    overflow: hidden;
}

.listing-view-left {
    float: left;
    width: calc(100% - 160px);
    padding-right: 15px;
}

.listing-view-right {
    float: left;
    width: 160px;
    text-align: right;
}

.listing-view-mobile-image {
    display: none;
}

@media screen and (max-width: 450px) {
    .listing-view-mobile-image {
        display: block;
        margin-bottom: 15px;
    }

    .listing-view-left {
        width: 100%;
    }

    .listing-view-right {
        display: none;
    }
}

.listing-view.header-image {
    max-width: 160px;
    max-height: 150px;
}

.listing-view-hr {
    height: 1px;
    background-color: #dedede;
    /*width: calc(100% - 180px);*/
    width: 100%;
    margin: 30px 0 -10px 0;
}

.sidebar-view.header-image {
    max-width: 100%;
    height: auto;
    margin-bottom: 1rem;
}

.sidebar-view-container h2 {
    font-size: 1rem;
}

.read-more-link {
    display: block;
    clear: both;
}

.rich-text img {
    max-width: 100%;
    height: auto;
}

.responsive-object {
    position: relative;
}

.responsive-object iframe,
.responsive-object object,
.responsive-object embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.box-header {
    border-bottom: 1px solid #dedede;
    color: #505050;
    font-size: 24px;
    padding-bottom: 5px;
    margin-top: 25px;
}

.box-header:first-child {
    margin-top: 0;
}

ul.box-list {
    list-style-type: none;
    margin: 15px 0;
    padding: 0;
}

.box-list li {
    display: block;
}

.box-list li a {
    color: #9c9c9c;
}

.footer {
    margin-bottom: 30px;
}

.footer-content {
    text-align: center;
    color: #7a7577;
}

.footer-content p {
    margin-bottom: 0;
}

.footer-content a {
    color: #505050;
    margin: 0 15px;
}

.tooltip {
    background: #000;
    color: #fff;
    font-size: 14px;
    z-index: 9999;
}

.tooltip .tooltip-arrow {
    border-color: #000;
}

.blog-post .blog-body table { 
    border-collapse: collapse;
    font-family: Arial;
    font-size: 0.9rem;
    font-weight: normal;
    text-align: center;
}

.blog-post .blog-body table thead { background-color: #00273f; color: #fff; }

.blog-post .blog-body table thead tr th {
    border-right: 1px solid #193a4f;
    font-weight: normal;
    padding: 10px;
    vertical-align: bottom;
}

.blog-post .blog-body table thead tr th[colspan="3"] {
    font-weight: bold;
    font-size: 1rem;
}

.blog-post .blog-body table thead tr th.thin {
    max-width: 100px;
}

.blog-post .blog-body table thead tr th.strong-border {
    border-right: 2px solid #193a4f;
}

.blog-post .blog-body table thead tr th:last-child { border-right: none; }
.blog-post .blog-body table tbody { background-color: transparent; color: #6b6567; }
.blog-post .blog-body table tbody tr td { padding: 10px; border-right: 1px solid #f4f4f4; }
.blog-post .blog-body table tbody tr td:last-child { border-right: none; }

.with-margin-top-h2 {
    margin-top: 80px;
}

@media screen and (max-width: 768px) {
    .with-margin-top-h2 {
        margin-top: 40px;
    }
}

.resources-header {
    border-bottom: 1px solid #d9d9d9;
    font-size: 26px;
    font-weight: bold;
    padding-bottom: 5px;
    margin-bottom: 5px;
    position: relative;
}

.resources-header.no-border {
    border: none;
}

.resources-header.resources-header-light {
    border-bottom: none;
    font-size: 16px;
    color: #96989a;
}

.resources-header > span {
    display: inline-block;
    max-width: 80%;
}

.resources-header.with-margin-top {
    margin-top: 80px;
}

.resources-header .resources-header-right {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
}

.resources-header .resources-header-more {
    display: inline-block;
    font-size: 16px;
    color: #464646;
    line-height: 38px;
    cursor: pointer;
}

.resources-header .resources-header-more a {
    font-size: 16px;
    color: #464646;
    line-height: 38px;
    cursor: pointer;
}

.waterzen-footer {
    margin-top: 30px;
}

.waterzen-footer p {
    color: #464646;
    font-family: 'Charter ITC TT';
    font-size: 18px;
}

.state-page-header {
    height: 100px;
    border: 1px solid #939faf;
    border-top-left-radius: 5px;
    border-top-right-radius: 5px;
    background-color: #3d516b;
    padding-left: 35px;
    padding-top: 20px;
    color: #fff;
    margin-top: 15px;
    margin-bottom: -21px;
}

.state-page-header-breadcrumb {
    margin: 0 0 2px 0;
    font-size: 14px;
}

.state-page-header-title {
    font-size: 26px;
    font-weight: bold;
    margin: 0;
}

.state-page-intro {
    margin-bottom: 30px;
}

.four-rows {
    list-style: none;
    padding: 0;
    margin: 0;
    font-size: 0;
    font-family: 'Figtree';
}

.four-rows li {
    display: inline-block;
    width: 25%;
    font-size: 15px;
    line-height: 1.8;
}

.four-rows li a {
    color: #353535;
    text-decoration: none;
}

.four-rows li.expandable {
    display: none;
}

.four-rows-nowrap {
    columns: 0 4;
    list-style: none;
    padding: 0;
    margin: 0;
    font-family: 'Figtree';
}

.four-rows-nowrap li {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.four-rows-nowrap li.expandable {
    display: none;
}

.four-rows-nowrap li a {
    color: #353535;
    text-decoration: none;
    width: 100% !important;;
    display: inline;
}

.three-rows-nowrap {
    columns: 0 3;
    list-style: none;
    padding: 0;
    margin: 0;
    font-family: 'Figtree';
}

.three-rows-nowrap li {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.three-rows-nowrap li a {
    color: #353535;
    text-decoration: none;
    width: 100% !important;
    display: inline;
}

@media screen and (max-width: 450px) {
    .four-rows li {
        width: 50%;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
    }

    .four-rows-nowrap {
        columns: 0 2;
    }

    .three-rows-nowrap {
        columns: 0 2;
    }

    .letter-content {
        flex-direction: column !important;
    }

    .letter {
        text-align: left !important;
    }
}

.page-header {
    color: #fff;
    padding-top: 25px;
    padding-bottom: 25px;
}

.page-header h1 {
    font-weight: bold;
    font-size: 32px;
    margin: 0;
}

.page-header h1 span {
    font-weight: normal;
}

.page-header h2 {
    font-weight: normal;
    font-size: 18px;
    margin: 10px 0 0 0;
}

.page-header .page-header-breadcrumb {
    font-size: 14px;
    margin-bottom: 20px;
}

.page-header .page-header-breadcrumb a {
    color: #fff !important;
}

/* https://stackoverflow.com/a/13184714 */
.anchor-offset {
    display: block;
    position: relative;
    top: -35px; /* sticky header height */
    visibility: hidden;
}

#main-image-container {
    position: relative;
}

#main-image-container img {
    width: auto !important;
    height: auto !important;
}

#main-image-container .main-image-license {
    position: absolute;
    bottom: 20px;
    right: 30px;
    color: #fff;
    background-color: #10181f;
    border-radius: 5px;
    padding: 4px 8px;
    font-size: 14px;
}

.home-page-header {
    min-height: 380px;
    color: #fff;
    padding-top: 45px;
    margin-bottom: -20px;
}

.home-page-header h1 {
    font-weight: bold;
    font-size: 46px;
    margin: 0;
}

.home-page-header h3 {
    margin: 35px 0 0 0;
    padding-bottom: 50px;
    max-width: 680px;
}

.home-page-header .container {
    padding: 0 45px;
}

@media (max-width:992px) {
    .home-page-header {
        min-height: 200px;
    }

    .home-page-header h1 {
        font-size: 28px;
    }

    .home-page-header h3 {
        margin-top: 15px;
        font-size: 20px;
    }

    .home-page-header .container {
        padding: 0 30px;
    }
}

.water-providers-by-letter h3 {
    font-weight: bold;
}

.letters-index {
    display: flex;
    flex-direction: row;
    justify-items: stretch;
    border-bottom: 1px solid #d9d9d9;
    border-top: 1px solid #d9d9d9;
    padding: 10px;
}

.letters-index a {
    color: #464646;
    flex-grow: 1;
}

@media screen and (max-width: 450px) {
    .letters-index {
        display: block;
    }

    .letters-index a {
        display: inline-block;
        padding: 5px 10px;
    }

    .water-provider-page-button {
        width: calc(100% - 50px);
    }

    .state-page-header {
        height: auto;
    }

    .state-page-header-title {
        padding-bottom: 20px;
    }
}

.letter-content {
    display: flex;
    flex-direction: row;
    border-bottom: 1px solid #d9d9d9;
    padding: 15px 0;
    margin: 15px 0;
}

.letter {
    width: 100px;
    font-size: 36px;
    font-weight: bold;
    text-align: center;
    flex-shrink: 0;
}

.letter-list {
    flex-grow: 1;
}


ul#water-provider-search-results-list, ul#blog-category-search-results-list {
    display: flex;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
    margin: 0;
    box-sizing: border-box;
    justify-content: space-between;
}

ul#water-provider-search-results-list *, ul#blog-category-search-results-list * {
    box-sizing: border-box;
}

ul#water-provider-search-results-list > li, ul#blog-category-search-results-list > li {
    width: calc(50% - 17px);
    margin-bottom: 35px;
    display: none;
}

ul#water-provider-search-results-list.expanded > li, ul#blog-category-search-results-list.expanded > li {
    display: block;
}

ul#water-provider-search-results-list > li:nth-child(-n+2), ul#blog-category-search-results-list > li:nth-child(-n+2) {
    display: block;
}


.water-provider-post-box {
    display: flex;
    flex-direction: column;
    border: 1px solid #dedede;
    border-radius: 5px;
    padding: 10px;
    width: 100%;
    height: 100%;
}

.water-provider-post-box .blog-intro {
    flex: 1 0 auto;
}

.water-provider-post-box  ul.water-provider-post-box-links {
    padding: 0;
    margin: 10px 0 0;
}

.water-provider-post-box  ul.water-provider-post-box-links li {
    width: 50%;
    display: inline-block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (max-width:768px) {
    ul#water-provider-search-results-list > li {
        width: 100%;
    }
}


.visible-on-mobile {
    display: none;
}

@media (max-width:992px) {
    .visible-on-mobile {
        display: block;
    }
    .visible-on-desktop {
        display: none;
    }
}

.pager {
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: space-between;
    list-style: none;
}


/* MAIN MENU */
#main-nav {
    display: flex;
    flex-grow: 3;
    min-width: 0;
}

#main-nav-mobile {
    display: none;
    width: 100%;
    position: absolute;
    top: 60px;
    border-top: 1px solid #d9d9d9;
    border-bottom: 1px solid #d9d9d9;
    background-color: #fff;
    z-index: 9999;
    padding: 20px 0;
    -webkit-box-shadow: 4px 4px 12px 0px #9698a0;
    -moz-box-shadow: 4px 4px 12px 0px #9698a0;
    box-shadow: 4px 4px 12px 0px #9698a0;
}

#main-nav-mobile .extra-space {
    padding-top: 50px;
}

#main-nav-mobile ul > li a.light {
    font-weight: normal;
}

#main-nav-mobile-trigger {
    display: none;
    width: 30px;
    color: #212529;
    font-size: 30px;
    align-self: center;
    margin-top: 4px;
    margin-right: 10px;
    text-decoration: none;
}

#main-nav-mobile-trigger-off {
    display: none;
}

@media only screen and (max-width: 992px) {
    #main-nav, #search {
        display: none !important;
    }
    #main-nav-mobile-trigger {
        display: block !important;
    }

    #service-provider-near-me {
        display: none !important;
    }
}

@media only screen and (min-width: 768px) {
    .header .header-container {
        padding: 0 45px;
    }
}

@media only screen and (min-width: 576px) {
    .header .header-container {
        padding: 0 45px;
    }
}

@media only screen and (max-width: 576px) {
    .header .header-container {
        padding: 0 45px;
    }
}

#main-nav > ul {
    display: flex;
    align-self: flex-end;
    list-style: none;
    margin-bottom: 7px;
    padding: 0 15px;
}

#main-nav > ul > li.nowrap {
    white-space: nowrap;
}

#main-nav > ul > li li {
    white-space: normal !important;
}
#main-nav > ul li {
    padding: 0 12px;
}

#main-nav > ul > li {
    height: 72px;
    display: flex;
    align-items: center;
}

#main-nav > ul li a {
    color: #353535;
}
#main-nav > ul li a.main-nav-bold {
    font-weight: bold;
}
#main-nav > ul li.main-menu-post-hidden {
    opacity: 0;
    padding: 0;
    width: 0;
}
#main-nav > ul li.main-menu-post-hidden a {
    display: none;
}
.main-nav-popup {
    display: flex;
    justify-content: space-between;
    position: absolute;
    top: 60px;
    left: 10px;
    z-index: 9999;
    width: 600px;
    /*background: #f8f8f8;*/
    background-color: #fff;
    border: 1px solid #f8f8f8;
    -webkit-box-shadow: 4px 4px 12px 0px #9698a0;
    -moz-box-shadow: 4px 4px 12px 0px #9698a0;
    box-shadow: 4px 4px 12px 0px #9698a0;
    border-radius: 5px;
}

.main-nav-popup.smaller {
    width: 400px;
}

.main-nav-popup .main-nav-popup-left {
    flex-basis: 58%;
    flex-grow: 1;
}

.main-nav-popup .main-nav-popup-left ul {
    list-style: none;
    padding: 20px 10px;
}

.main-nav-popup .main-nav-popup-left ul li {
    padding: 0 10px;
}

.main-nav-popup .main-nav-popup-left ul li a {
    display: inline-block;
    padding: 10px;
    text-decoration: none;
    width: 100%;
}

.main-nav-popup .main-nav-popup-left ul li a:hover strong,
.main-nav-popup .main-nav-popup-left ul li.active a strong {
    text-decoration: underline;
}

.main-nav-popup .main-nav-popup-left ul li strong {
    font-weight: bold;
    display: block;
}

.main-nav-popup .main-nav-popup-right {
    flex-basis: 42%;
    background: #f8f8f8;
    padding: 20px;
}

.header .header-container .search {
    transition: 0.3s ease-out;
    background-color: #fff;
    display: block !important;
    position: relative  !important;
    top: auto  !important;
    right: auto  !important;
    align-self: center;
    margin-bottom: 7px;
}

.header .header-container .search.hidden {
    width: 35px !important;
    border: none !important;
}

#main-nav-mobile ul {
    list-style: none;
    padding: 0;
    margin: 0;
    transition: 0.5s;
}
#main-nav-mobile ul > li {
    width: 100%;
    padding: 5px 15px;
}

#main-nav-mobile ul > li a {
    color: #353535;
    font-weight: bold;
}

#main-nav-mobile ul > li .fa {
    float: right;
}

#main-nav-mobile ul > li .fa.main-nav-mobile-submenu-trigger-off {
    display: none;
}

#main-nav-mobile ul > li li a {
    font-size: 14px;
    font-weight: normal;
}

#main-nav-mobile #search-mobile {
    height: 34px;
    border: 1px solid #dedede;
    border-radius: 5px;
    color: #a1a3a5;
    background-image: url(/static/images/search-icon.png);
    background-repeat: no-repeat;
    background-position: 10px 7px;
    padding-left: 36px;
    font-size: 14px;
    line-height: 34px;
    width: 100%;
    margin-bottom: 10px;
}

#service-provider-near-me {
    align-self: center;
    margin-bottom: 7px;
    margin-right: 20px;
    background: #fff;
    z-index: 9999;
}

#service-provider-near-me:hover {
}

#service-provider-near-me a {
    color: #000;
    border: 2px solid black;
    padding: 6px 8px;
    border-radius: 16px;
    white-space: nowrap;
}
#service-provider-near-me a:hover {
    text-decoration: none;
    background: #eee;
}
/* END MAIN MENU */



footer {
    width: 100%;
    padding: 70px 0;
    color: #fff;
}

footer .clickable:hover {
    cursor: pointer;
    text-decoration: underline;
}

footer h1.sitename-text {
    font-weight: 200;
}

footer h1.sitename-text strong {
    font-weight: 900;
}

footer .container {
    padding-left: 45px;
    padding-right: 45px;
}

footer .footer-categories {
    display: flex;
    flex-wrap: wrap;
    margin-top: 40px;
}

footer .blog-body p:last-child {
    margin-bottom: 0;
}

footer .footer-categories .footer-category {
    flex-basis: 20%;
    margin-bottom: 40px;
}

footer .footer-categories .footer-category span.footer-header {
    font-size: 18px;
    font-weight: bold;
}

footer .footer-categories .footer-category a {
    color: #fff;
}

footer .footer-categories .footer-category ul {
    margin: 10px 0 0 0;
    padding: 0;
    list-style: none;
}

footer .footer-categories .footer-category ul a {
    color: #fff;
}

footer #footer-bottom {
    border-top: 1px solid #fff;
    width: 100%;
    display: flex;
}

footer #footer-bottom .footer-links > p {
    padding: 10px 0 0 0;
    margin: 0;
}

footer #footer-bottom .footer-links > p a {
    padding: 0 10px;
    color: #fff;
    border-right: 1px solid #fff;
}

footer #footer-bottom .footer-links > p a:first-child {
    padding-left: 0;
}

footer #footer-bottom .footer-links > p a:last-child {
    border: none;
}

footer #footer-bottom .footer-copyrights {
    padding: 10px 10px 0 0;
}

footer .blog-body a {
    color: #fff !important;
    text-decoration: underline;
}

@media only screen and (max-width: 768px) {
    footer .footer-categories .footer-category {
        flex-basis: 100%;
        padding: 0;
    }
    
    footer #footer-bottom {
        flex-wrap: wrap;
    }

    footer #footer-bottom .footer-links, footer #footer-bottom .footer-copyrights {
        flex: 0 0 100%;
        text-align: center !important;
        padding: 10px 0 0 0 !important;
    }
}

.page-buttons-list {
    background: #e8f0f8;
    color: #4c6980;
    padding: 15px;
}

.page-buttons-list ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.page-buttons-list ul li a {
    color: #4c6980;
    text-decoration: underline;
    cursor: pointer;
}

.page-buttons-side ul li {
    padding: 10px 0;
}

.page-buttons-sticky {
    position: -webkit-sticky; /* Safari */
    position: sticky;
    top: 0;
    z-index: 8888;
    margin-bottom: -15px;
}

.page-buttons-sticky .page-buttons-list {
    margin: 25px;
}

.page-buttons-sticky .page-buttons-list ul {
    padding-left: 15px;
}

.page-buttons-sticky .page-buttons-list ul li {
    padding: 0 10px;
}

.page-buttons-sticky .page-buttons-list * {
    display: inline-block;
}

.boil-water-advisory {

}

.boil-water-advisory .boil-water-advisory-text {
    background: #fcf0ae;
    color: #464646;
    padding: 15px;
    margin: 25px;
}

.boil-water-advisory .boil-water-advisory-text p {
    margin-bottom: 0;
}

@media (max-width: 450px) {
    .page-buttons-side {
        margin-bottom: 30px;
    }

    .page-buttons-sticky {
        position: relative;
        top: auto;
    }

    .page-buttons-sticky .page-buttons-list {
        margin: 30px 15px !important;
    }

    .page-buttons-sticky .page-buttons-list ul {
        padding: 0 !important;
    }
    .page-buttons-sticky .page-buttons-list ul li {
        padding: 10px 0 !important;
        width: 100%;
    }

}


.list-topics {
    margin: 0;
    list-style: none;
    border: 1px solid #dedede;
    border-radius: 5px;
    padding: 10px;
}

.list-topics li {
    padding: 10px;
    border-bottom: 1px solid #dedede;
}

.list-topics li.list-topics-topic-hidden {
    display: none;
}

.list-topics li:first-child {
    padding-top: 0;
}

.list-topics li:last-child {
    padding-bottom: 0;
    border-bottom: none;
}

.list-topics li a {
    color: black;
}

.list-topics li a#show-more-topics {
    color: #1588e2;
}

.blinking {
    animation: blinking 1s linear infinite;
}

@keyframes blinking {
    50% {
        opacity: 0;
    }
}

#map-container {
    width: 100%;
}

#map-container > div {
    max-width: 690px; margin: 0 auto;
}

#map-container .map-placeholder {
    max-width: 690px;
}

#map-container .map-placeholder-inner {
    width: 100%;
    padding-top: 61.6%; /* 690x425 Aspect Ratio -> 425/690 = 61.6%*/
    position: relative;
}

/* ######### LOADER ######### */
.spinner {
    animation: rotate 2s linear infinite;
    z-index: 2;
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -25px 0 0 -25px;
    width: 50px;
    height: 50px;
}

.spinner .path {
  stroke: hsl(210, 70%, 75%);
  stroke-linecap: round;
  animation: dash 1.5s ease-in-out infinite;
}


@keyframes rotate {
    100% {
        transform: rotate(360deg);
    }
}

@keyframes dash {
    0% {
        stroke-dasharray: 1, 150;
        stroke-dashoffset: 0;
    }
    50% {
        stroke-dasharray: 90, 150;
        stroke-dashoffset: -35;
    }
    100% {
        stroke-dasharray: 90, 150;
        stroke-dashoffset: -124;
    }
}


/* ######### LOADER ######### */

#latest-updates-load-more, #latest-updates-load-more-spinner {
    text-align: center;
    padding: 20px;
    position: relative;
    height: 64px;
}

#latest-updates-load-more span {
    cursor: pointer;
    border: 2px solid black;
    padding: 6px 8px;
    border-radius: 16px;
    white-space: nowrap;
    color: black;
}

#latest-updates-load-more span:hover {
    text-decoration: none;
    background: #eee;
}

.alternative-service-providers-hidden {
    display: none;
}

.alternative-service-providers-hidden-wq {
    display: none;
}
.water-quality-report-alert {
    padding: 10px 20px;
    margin-top: 20px;
    border: 1px solid #cecece;
    background-color: #fff4cf;
    color: #000000;
    border-radius: 4px;
}

.alternative-water-quality-reports-hidden {
    display: none;
}
