﻿html, body {
    padding: 0;
    margin: 0;
}

html, body, h1, h2, h3, h4, h5, h6, p, div, section {
    font-family: 'Lora',serif;
    color: black;
}

span, a, a:link, a[href] {
    color: inherit;
}

body {
    font-size: 16px;
    background-color: white;
}

h1, h2, h3, h4, h5, h6 {
    margin-bottom: 1em;
}

body main {
    background-color: white;
    padding-top: 0;
}

main.start-white section:nth-of-type(even), main.start-blue section:nth-of-type(odd) {
    background-color: #03334a;
    color: white;
}

    main.start-white section:nth-of-type(even) *,
    main.start-blue section:nth-of-type(odd) * {
        color: white;
    }


/* Begin Header */
header ul {
    list-style: none
}

    header ul li {
        display: inline-block
    }

header .top {
    box-shadow: 1px 1px 13px #000;
    position: relative;
    background-color: #03334a;
    text-align: right
}

    header .top, header .top div {
        height: 2.5em;
        line-height: 2.5em;
        font-size: 10pt;
    }

.dnnEditState header .top, header .top, .dnnEditState header .top div {
    height: auto;
}
    header .top a, header .top a:link, header .top a:visited, header .top a:hover, header .top a:after {
        color: white;
        border-bottom-color: white
    }

    header .top p a {
        font-size: 10pt;
        padding-right: 3em;
    }

        header .top a:after {
            top: 85%;
        }

    header .top ul li {
        margin-left: 3em
    }

header .bottom {
    position: relative;
    z-index: 6;
    padding: 1em 0 2px;
    box-shadow: 0 3px 10px #000
}

    header .bottom .middleHeaderContent,
    #Phantom .middleHeaderContent {
        width: 60%;
        display: inline-block;
        float: right;
    }

    header .bottom .pageTitle,
    #Phantom .pageTitle{
        font-size: 18pt;
        line-height: 22pt;
        font-weight: bold !important;
        display: inline-block;
        width: 200px;
        font-weight: normal;
        text-shadow: 2px 2px 3px grey;
        margin-left: 0.5em;
        position: relative;
        top: 3px;
    }

.departmentPage.logo-container {
    top: -7px;
}
.logo-container {
    position: relative;
    z-index: 9;
    top: -8px;
    cursor: pointer;
    display: inline-block;
}

    .logo-container > a:after {
        content: "";
        display: none
    }


header .bottom ul,
#Phantom ul{
    display: inline-block;
    width: 82%;
    line-height: 60px;
    font-size: 14pt;
    text-align: center
}

    header .bottom ul li,
    #Phantom ul li{
        margin-right: 1em;
        margin-left: 1em
    }

        header .bottom ul li > a,
        #Phantom ul li > a{
            z-index: 9;
            cursor: default;
            user-select: none;
            -webkit-user-select: none
        }

            header .bottom ul li > a[href],
            #Phantom  ul li > a[href]{
                cursor: pointer
            }

        header .bottom ul li a:after,
        #Phantom ul li a:after{
            z-index: 99;
            top: 75%
        }

        header .bottom ul li > div:before,
        #Phantom ul li > div:before {
            content: ' ';
            position: absolute;
            left: 0;
            right: 0;
            height: 8px;
            top: 34px;
            background: linear-gradient(#151515,#818181,#c1c1c1,#fbfbfb)
        }

header .expanding-table {
    width: 100%
}

    header .expanding-table td {
        width: 287px
    }

    header .expanding-table a:hover {
        text-decoration: underline
    }

    header .expanding-table a:after {
        position: relative;
        left: 0;
        top: 0;
        border-bottom: 0;
        z-index: 99
    }

    header .expanding-table a:hover:after {
        content: '\00a0\00a0\00bb';
        text-decoration: none;
        position: relative;
        left: 0;
        top: 0;
        border-bottom: 0
    }


#Phantom {
    width: 100%;
    position: fixed;
    z-index: 99;
    -webkit-transition: all 0.25s;
    transition: all 0.25s;
    height: 5em;
    padding-top: 1em;
    background-color: white;
}

    #Phantom #Logo {
        height: 70px;
    }

    #Phantom.undocked {
        top: -100px;
        height: 0em;
    }

    #Phantom.docked {
        top: 0;
        height: 6em;
        box-shadow: 0 0 10px black;
        opacity: 0.99;
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=99)";
    }


/* Begin Front Page specific styles */
.homepage h2 {
    text-align: center
}

/* --- Google Search Bar */
.google-cse div {
    position: relative;
    text-align: center;
}

.google-cse {
    position: absolute;
    width: 100%; /*max-width:1024px;left:50%;margin-left:-512px;top:10px;*/
    z-index: 1;
}

.dnnEditState .google-cse {
    position: relative;
}

.google-search-button {
    position: absolute;
    display: block;
    right: 0;
    top: 0;
    width: 2.8em;
    height: 100%;
    background: transparent url(/Images/search-icon.svg) no-repeat 50%;
    background-size: 1.25em 1.25em;
    text-indent: -300px;
    overflow: hidden;
    box-shadow: none;
    border: none
}

.google-search-box {
    width: 100%;
    height: auto !important;
    padding: .75em;
    padding-right: 3em;
    font-size: 1em !important;
    border: 0 none;
    background: white;
    background: hsla(0,0%,100%,.85);
    transition: all .25s ease-out;
    box-shadow: 0 .5em 1em rgba(34,34,34,.3);
    border-radius: 0 !important;
    -webkit-appearance: none !important;
    -webkit-border-radius: 0 !important;
    text-align: center;
}

    .google-search-button:active, .google-search-button:focus, .google-search-box:active, .google-search-box:focus {
        background-color: white !important
    }

.search-hotlinks,
.search-hotlinks div {
    height: 2em;
    line-height: 2em;
    background-color: hsla(0,0%,25%,0.85);
    color: white;
    width: 100%;
    font-size: 0.98em;
}

.dnnEditState .search-hotlinks,
.dnnEditState .search-hotlinks div {
    height: auto;
}

    .search-hotlinks span {
        padding-left: 3em;
        user-select: none;
        color: white;
    }

    .search-hotlinks ul {
        list-style: none;
        padding: 0;
        margin: 0;
        display: inline-block
    }

        .search-hotlinks ul > li {
            display: inline-block;
            padding: 0 10px;
            color: white;
        }

    .search-hotlinks a:after {
        top: 85%;
    }

/* --- Park Image Parallax */
#ParallaxBanner {
    background-color: rgba(45,154,183,0.1) !important;
    height: 35vw;
    min-height: 400px;
    display: table;
    width: 100%;
    position: relative
}

.ParallaxFilter {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background-color: #000;
    opacity: .47;
    margin-left: 0
}

#ParallaxBanner > .content-container {
    display: table;
    height: 100%;
    width: 100%
}

#ParallaxBanner > div > div {
    text-align: right;
    display: table-cell;
    vertical-align: middle;
    color: white;
    padding-right: 30px
}

#ParallaxBanner * {
    color: white;
}


/* --- Maps */
#MapSelector {
    text-align: center;
    width: 100%
}

    #MapSelector a {
        color: white;
        background-color: #023c58;
        width: 100%;
        border-radius: 0;
        width: 82%
    }

        #MapSelector a:hover {
            background-color: #006694
        }

        #MapSelector a[selected] {
            background-color: #012231;
            box-shadow: 0 0 0
        }

/* Jumbotron */
.homepage .jumbotron, .homepage .jumbotron img {
    background-image: none;
    height: auto;
    min-height: 4.33em;
}

.jumbotron {
    position: relative;
    background-image: url(../Images/HeaderBG.png);
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    border-bottom: 2px solid #9d3324
}

    .jumbotron > .jumbotronFilter {
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        background-color: #01344a;
        opacity: .65
    }

.above-content {
    margin: 1em 0;
    border-bottom: 1px solid gray;
}
#breadcrumb {
    padding-left: 10px;
    position: relative;
    display: inline-block;
    width: 70%;
    height: 30px;
    white-space: nowrap;
}

    #breadcrumb img {
        margin: 0 10px;
    }

.socialMedia {
    position: relative;
    display: inline-block;
    width: 19%;
    right: -9%;
    height: 30px;
    text-align: justify;
    vertical-align: middle;
    text-align: center;
}

.socialMedia a[href] {
    margin: 0 15px;
}
    .socialMedia a[href]:after {
        content: "";
        width: 0;
        display: none;
    }

    .socialMedia a[href] span {
        display: inline-block;
        height: 30px;
        width: 30px;
        background-position: 0 0;
        background-repeat: no-repeat;
    }

        .socialMedia a[href] img:hover, .socialMedia a[href] span:hover {
            background-position: 0 -30px;
        }

.dnnEditState .socialMedia {
    height: 100px;
}

/* Left Navbar */
nav {
    width: 16%;
    height: 100%;
    display: inline-block;
    vertical-align: top;
    -webkit-transition: top .25s;
    transition: top .25s
}

nav ul {
    list-style: none;
}

nav ul li {

}

    nav  a {
        display: block;
        margin-bottom: 1em;
        position: relative;
        width: 100%
    }

#responsiveNavPlaceholder { display: none; }
/* Footer */
footer {
    padding: 3em 3vw;
    position: relative;
    min-height: 185px;
    background-color: transparent;
    background-image: url(../Images/FooterBG.jpg);
    background-position: center -3px;
    color: white;
}

    footer div, footer a, footer h1, footer h2, footer h3, footer h4, footer h5, footer h6, footer a[href], footer a:link, footer a:visited,
    footer p {
        color: white;
    }

    footer > .footerFilter {
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background-color: #000;
        opacity: .65
    }

/* Default Tag Styles */
a[href], a:link, a:active, a:visited {
    text-decoration: none;
    transition: .25s text-decoration;
    position: relative;
    display: inline-block
}

    a[href]:after {
        position: absolute;
        left: 50%;
        top: 100%;
        width: 0;
        content: " ";
        border-bottom: 1px solid;
        -webkit-transition: all .25s;
        transition: all .25s
    }

a:hover:after {
    left: 0;
    width: 100%
}

.page-content ul li a[href] {
    vertical-align: text-top;
}

a.style-reset {
    all: unset;
    position: relative;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    border-bottom: none;
    border: none;
    text-decoration: underline;
    color: initial;
    color: #00E;
    transition: none;
    cursor: auto
}

    a.style-reset:link, a.style-reset:active, a.style-reset:hover {
        text-decoration: underline;
        cursor: pointer;
    }

    a.style-reset:visited {
        color: #551A8B
    }

    a.style-reset:after {
        content: "";
        display: none
    }

a img {
    border: 0
}

main {
    background-color: white;
    position: relative;
    display: block;
}

    main > section, main > div {
        padding: 3em 3vw;
    }

section > h2 {
    margin-top: 0;
    margin-left: 0
}

section > * {
    margin-left: 1em
}

input[type="search"] {
    font-size: 10pt;
    height: 2em;
    border-radius: 0 !important;
    -webkit-appearance: none !important;
    -webkit-border-radius: 0 !important;
}

/* Class Styles */
.content-container {
    width: 90%;
    max-width: 1024px;
    margin: auto;
    position: relative;
    height: 100%
}
    /* wraps content and nav */
    .content-container:after {
        content: "";
        display: table;
        clear: both
    }

.content {
    display: inline-block;
    width: 100%;
    padding-left: 1.5%;
    border-left: 0 solid gray;
    min-height: 37vh;
}

.padding-margin-clear {
    padding: 0;
    margin: 0
}

.full-width {
    width: 100%
}

table.full-width {
    border-collapse: collapse
}

.full-height {
    height: 100%
}

.button {
    border: none;
    padding: 15px 32px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    font-size: 16px
}

a.button {
    box-sizing: border-box;
    color: white;
    background-color: #012231;
    border-radius: 5px;
    transition: background .25s;
    cursor: pointer
}

    a.button:hover {
        background-color: #006694;
        box-shadow: 0 0 10px #000
    }

    a.button:after {
        display: none
    }

.default-table {
    font-size: 10pt
}

    .default-table tbody tr:hover {
        background-color: #9B9B9B !important
    }

    .default-table thead {
        background-color: #03334a;
        color: white
    }

    .default-table td, .default-table th {
        height: 2em;
        padding: 5px
    }

    .default-table tbody tr:nth-child(even) {
        background-color: #dedede
    }

.left {
    float: left;
}

.right {
    float: right
}

.half-width {
    width: 50%;
}

.img-left {
    float: left;
    text-align: center;
    margin-right: 1em;
    display: inline-block;
    height: 100%
}

.img-right {
    float: right;
    text-align: center;
    margin-left: 1em
}

.clear-fix {
    content: "";
    display: table;
    clear: both;
    width: 100%;
}

.underlined-list {
    list-style: none;
    margin-left: 0;
    padding-left: 0;
    margin-top: 16px;
}

    .underlined-list > li {
        display: block;
        width: 100%;
        margin-top: 1em;
    }

        .underlined-list > li > h1, .underlined-list > li > h2, .underlined-list > li > h3, .underlined-list > li > h4, .underlined-list > li > h5, .underlined-list > li > h6 {
            margin-bottom: 0;
            padding-bottom: 2px;
            border-bottom: 1px solid gray
        }

            .underlined-list > li > h5 > span {
                float: right;
                position: relative;
                top: -4px;
            }

                .underlined-list > li > h5 > span img {
                    height: 20px
                }

        .underlined-list > li > table {
            margin-left: 1em
        }

            .underlined-list > li > table td:first-child {
                width: 75px
            }

.pull-left {
    float: left;
}

.sm-graphic-shadow {
    box-shadow: 0 0 5px gray;
}

.md-graphic-shadow {
    box-shadow: 0 0 10px #0A0A0A;
}

.lg-graphic-shadow {
    box-shadow: 0 0 15px #000000;
}

.additional-margin { margin-left: 3em; }

.lg-additional-margin { margin-left: 6em; }

/* Emergency Closure */
#CCGClosures {
    text-align: center;
    background-color: #9e0000 !important;
    color: white;
    padding-top: 1em;
    padding-bottom: 1em;
    font-weight: bold;
}

    #CCGClosures > h1, #CCGClosures > h2, #CCGClosures > h3, #CCGClosures > h4, #CCGClosures > h5, #CCGClosures > h6 {
        padding-top: 0;
        margin-top: 0;
    }

    #CCGClosures p {
        margin: 0;
    }

    #CCGClosures table {
        width: 100%;
    }

        #CCGClosures table tr td {
            text-align: center;
        }

/* Fix for Calendar.io and default anchor styles of this template. */
.fc .fc-month-view a,
.fc .fc-month-view a:link,
.fc .fc-month-view a:active,
.fc .fc-month-view a:visited {
    color: white;
    display: block;
}

.fc fc-month-view a:hover {
    display: inline-block !important;
}

/* ---------- Large-Only Styles ---------- */
@media screen and (min-width:999px) {
    #navbarExpander {
        display: none
    }

    header .bottom ul li > div {
        height: 0;
        padding: 0;
        overflow: hidden;
        position: absolute;
        z-index: 8;
        left: 0;
        right: 0;
        background-color: white;
        font-size: 12pt;
        transition: opacity 1s;
        opacity: 0
    }

    header .bottom ul li:hover > div {
        bottom: -178px;
        height: 177px;
        opacity: 1;
        padding: 33px 0 0 25px
    }

    #UpcomingEvents ul {
        list-style: none;
        text-align: center;
        color: white;
        margin-left: 0;
        padding: 0;
        margin-top: 40px;
        margin-bottom: 40px
    }

        #UpcomingEvents ul > li {
            display: inline-block;
            vertical-align: top;
            width: 18.3%;
            max-width: 16vw;
            height: 265px;
            margin: 0 25px;
            background-color: #03334a;
            padding: .33em;
            text-align: center;
            border: 2px solid #9e3223;
            outline: 13px solid #03334a;
            cursor: pointer;
            transition: .25s
        }

            #UpcomingEvents ul > li:hover {
                background-color: #006694;
                outline-color: #006694
            }

    .tab-page {
        height: 391px
    }

    .jumbotron, .jumbotron img {
        height: 200px
    }

}
/* ---------- Small-Only Styles ---------- */
@media screen and (max-width:1000px) {
    #Phantom { display: none; }

    body {
        background-image: none;
    }

    #ParallaxBanner {
        background-image: url(../images/sec-parks.jpg);
        background-size: 400%;
        background-position: 50% 50%;
        background-repeat: no-repeat;
    }

    a:after {
        display: none;
    }

    a:hover:after {
        display: none;
    }

    /* Header */
    .navbar-brand {
        left: 30px;
        height: 50px;
        position: relative;
    }

    header .bottom .content-container { width: 100%; }

    header .top ul {
        display: none
    }

    header .bottom .pageTitle, #Phantom .pageTitle {
        width: 55%;
        font-size: 1.25em !important;
        left: 28px;
        top: -6px;
    }

    header .bottom ul {
        display: block;
        position: absolute;
        left: -110vw;
        width: 100%;
        background-color: white;
        box-shadow: 0px 15px 15px #000000;
        transition: left 1s;
        text-align: left;
        min-height: 100vh
    }

        header .bottom ul.active {
            display: block;
            left: 0
        }

        header .bottom ul li {
            display: block;
            width: 92%;
            padding-left: 1em;
            margin: 0
        }

            header .bottom ul li > div {
                position: relative;
                left: auto;
                right: auto;
                overflow-y: hidden;
                height: 0;
                font-size: 10pt;
                transition: height 1s
            }

                header .bottom ul li > div.active {
                    height: auto
                }

            header .bottom ul li:hover > div {
                opacity: 1;
                top: 0;
                left: 0
            }

            header .bottom ul li > div:before {
                display: none
            }

            header .bottom ul li > div img {
                display: none
            }

    /* Navbar */
    nav {
        display: none
    }

    #navbarExpander {
        display: block;
        position: absolute;
        right: 10px;
        top: -2px;
        cursor: pointer;
        height: 30px;
        padding: 6px
    }

        #navbarExpander:hover {
            background-color: #f3f3f3
        }

        #navbarExpander:active {
            background-color: white;
            box-shadow: 0 0 2px gray inset
        }

    #responsiveNavPlaceholder {
        display: block;
    }
    #responsiveNavPlaceholder select {
        width: 100%;
        height: 2em;
        font-size: 11pt;
    }

    .breadcrumb {
        margin-left: 1em;
        padding-left: 10px;
        white-space: nowrap;
    }

        .breadcrumb img {
            margin-left: 10px;
        }

    .socialMedia {
        display: none;
    }

        /* Front-Page Only */
        #PopularResources table tr > td {
            display: block;
            width: 100%
        }

    #UpcomingEvents ul > li {
        display: block
    }

        #UpcomingEvents ul > li h3, #UpcomingEvents ul > li h2 {
            font-size: 14pt;
            display: inline-block;
            margin: 0;
            padding: 0
        }

        #UpcomingEvents ul > li p {
            margin: 0;
            padding: 0
        }

    #UpcomingEvents ul {
        list-style: none;
        column-count: 1;
        padding-left: 0;
        padding-right: 40px
    }

        #UpcomingEvents ul li {
            counter-increment: step-counter;
            position: relative;
            margin-bottom: 45px;
            break-inside: avoid-column;
            text-align: right
        }

            #UpcomingEvents ul li:before {
                content: " ";
                margin-left: 5px;
                font-size: 80%;
                background-color: #9e3223;
                color: white;
                font-weight: 700;
                padding: 3px 8px;
                border-radius: 3px;
                position: absolute;
                right: -30px;
                height: 100%;
                display: flex;
                align-items: center
            }

    #LatestNews ol {
        column-count: 1
    }

    #ParallaxBanner {
        background-size: cover;
        background-position: 50% 0
    }

        #ParallaxBanner > div > div > h4 {
            font-size: 12pt
        }

        #ParallaxBanner > div > div > p {
            font-size: 12pt;
            line-height: 18pt
        }



    /* Jumbotron */
    .jumbotron, .jumbotron img {
        height: 20vw;
        min-height: 100px
    }

    /* Latest News */
    #LatestNews a > h5:after {
        display: none;
    }

    /* Council */
    ul#CouncilDistrictScroll li > div.districtDetails {
        float: none;
    }

    ul#CouncilDistrictScroll li > div.districtImage {
        display: none;
    }

    /* Class Styles */
    .content {
        width: 90%;
        padding-left: 2%
    }

    .expanding-table tr, .expanding-table tr td {
        display: block;
        width: 100%
    }

        .expanding-table tr td {
            height: 2.75em;
            line-height: 2.75em
        }

    .expanding-table td:hover > a {
        text-decoration: underline
    }

        .expanding-table td:hover > a:after {
            content: '\00a0\00a0\00bb';
            text-decoration: none;
            position: relative;
            left: 0;
            top: 0;
            border-bottom: 0
        }

    .expanding-table td a {
        display: inline-block;
        width: 100%
    }

    .jcarousel span {
        font-size: 8pt;
        text-shadow: none
    }

    .hide-on-shrink {
        display: none
    }

    .stretch-on-shrink {
        width: 100% !important;
        float: none
    }

    table.stretch-on-shrink tr td {
        display: block;
        box-sizing: border-box;
        width: 100%
    }

    .center-on-shrink {
        text-align: center
    }

    .img-left.center-on-shrink, .img-right.center-on-shrink {
        float: none;
        display: block;
        margin: auto
    }

    .left-on-shrink {
        text-align: left !important
    }

    /* Emergency Closure */
    #CCGClosures {
        font-size: 10pt;
    }

        #CCGClosures table tr td {
            display: block;
            width: 100%;
        }
}
/* ---------- Extra-Small-Only Styles ---------- */
@media screen and (max-width: 500px) {
    #MainCarousel {
        height: 70vw
    }

        #MainCarousel img {
            -webkit-transform: scale(1.75,1);
            transform: scale(1.75,1);
            height: 70vw
        }

        #MainCarousel .jcarousel li {
            overflow: hidden
        }

    form.google-cse > div .google-search-button {
        height: 100% !important;
    }

    .search-hotlinks {
        display: none
    }
}
