html, body { color: #333; font-family: myriad-pro, sans-serif; font-size: 16px; -webkit-font-smoothing: antialiased; }
.container { padding: 0; width: 100%; }
.row { margin: 0; }
#content > .row > div { padding: 0 1.5% 12px; }
.vertical-center > div { float: none; display: inline-block; margin-left: -.5%; vertical-align: middle; }
.vertical-center > div:first-of-type { margin: 0; }

/* Links */
a { transition: background-color .2s, color .2s; }
a:hover,
a:focus { text-decoration: none; }
.button { background-color: #c47; border-radius: 14px; border: 0; color: #fff; display: inline-block; letter-spacing: .05em; margin-top: 12px; padding: 4px 16px; transition: background-color .2s; }
.button:hover { background-color: #b16; color: #fff; }
.button:focus { color: #fff; }

#skiptocontent { background-color: #fff; border-radius: 8px; box-shadow: 2px 2px 8px 0 #000; font-size: 1.3em; left: -9999px; padding: 3px 12px; position: absolute; top: -9999px; }
#skiptocontent:focus { left: 8px; top: 8px; }
.ada-element { left: -9999px; position: absolute; }

.vc:before { content: ""; display: inline-block; height: 100%; vertical-align: middle; }
.vc > * { display: inline-block; vertical-align: middle; }

.list-var { min-height: 110px; padding-left: 120px; position: relative; }
.list-var > img { left: 0; position: absolute; width: 100px; }

.circ { background: #c47; border-radius: 50%; height: 100px; line-height: 100px; text-align: center; width: 100px; }
.circ img { width: 60px; }

/* 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; }
img { max-width: 100%; }

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

/* Tables */
table { border: 1px solid #333; margin: 14px 0; width: 100%; }
table tr th { border: 1px solid #333; padding: 2px 4px; }
table tr td { border: 1px solid #333; padding: 2px 4px; }

/* Quick Header */
.header { background-color: #c47; color: #fff; padding: 14px 20px; position: relative; }
.header h1 { display: inline-block; font-size: 1.3em; margin: 0; }
.header .nav { float: right; top: 0; right: 0; }
.header ul { margin: 0; padding: 0; }
.header li { display: inline-block; margin-left: 28px; }
.header li a { color: #fff; display: block; }
.header li a:hover { color: #ddd; }
#mobile-menu { background-color: transparent; border: 0; cursor: pointer; display: none; font-size: 1.3em; padding: 0 4px; }

/* Quick Footer */
.footer { background-color: #c47; color: #fff; padding: 14px 20px; }
.footer p { margin: 0; }

/* Sticky Footer (uncomment if needed; set padding-bottom of ".container" to logical height based on what ends up in the footer) */
html, body { height: 100%; }
.container { min-height: 100%; padding-bottom: 140px; position: relative; }
.footer { background-color: #c47; bottom: 0; height: 140px; position: absolute; width: 100%; }

/*********************************************/
/******   Custom CSS  ************************/
/*********************************************/

.header { background: #212c5d; margin-bottom: 36px; padding: 18px 44px 18px 24px; }
.header:before { background: #f8e314; content: ""; left: -28px; height: 28px; position: absolute; top: 100%; width: 100%; } 
.header:after { border: 14px solid transparent; border-color: #f8e314 transparent transparent #f8e314; content: ""; position: absolute; right: 0; top: 100%; }
.header h1 { font-size: 2em; font-weight: 700; text-transform: uppercase; width: 300px; }
.header .nav { margin-top: 21px; }
.header .nav a { font-size: 1.2em; position: relative; }
.header .nav .active > a:after { background: #0c75ba; content: ""; height: 6px; left: 0; margin-top: 6px; position: absolute; top: 100%; width: 100%; }
.header .nav ul li{ position: relative; }
.header .nav ul ul { background: #0c75ba; border-top: 4px solid #212c5d; display: none; left: 50%; margin: 0 0 0 -90px; padding: 1px 12px; position: absolute; text-align: center; width: 180px; }
.header .nav ul ul li { border-top: 1px solid #fff; display: block; font-weight: 700; margin: 0; padding: 6px 14px 8px; }
.header .nav ul ul li:first-of-type { border: 0; }
.header .nav ul li:hover ul { display: block; }

h2 { color: #212c5d; font-weight: 700; }

#content > .row { padding: 28px 5% 34px; }

#progress { display: none; font-size: 1.8em; margin-bottom: 18px; }
#progress span { color: #0c75ba; font-size: 1.6em; font-weight: 900; margin-right: 4px;}

.map { background: #0c75ba; margin-top: 18px; }
.map img { width: 100%;}
.map h2 { background: #f8e314; display: inline-block; height: 52px; line-height: 52px; margin: 0; padding: 0 18px 0 6.5%; position: relative; }
.map h2:after { border: 26px solid transparent; border-color: #f8e314 transparent transparent #f8e314; content: ""; left: 100%; position: absolute; top: 0; }

#project-status div { background: #eaf2f8; font-weight: 700; margin-top: 14px; padding: 10px 14px; }

#top-row { display: flex; align-items: center; flex-wrap: wrap; }
#top-row div:last-of-type { text-align: center; }
#top-row div:last-of-type a { border-radius: 100px 28px 28px 100px; display: block; margin: 8px auto 0; max-width: 356px; padding: 0; width: 70%; }
#top-row div:last-of-type a:hover { box-shadow: 0 0 14px 0 #aaa; }

#env-assessment-list { list-style-type: none; margin: 0; padding: 0; }
#env-assessment-list .list-var { min-height: 88px; padding-left: 104px; }
#env-assessment-list li h3 { font-weight: 700; }
#env-assessment-list li img { width: 74px; }

#phase-options { padding-top: 0 !important; }
#phase-options > div { padding-left: 106px !important; padding-right: 40px !important; }
#phase-options .list-var { margin-left: -106px; padding-left: 45px; }
#phase-options img { display: block; width: 90px; z-index: 1; }
#phase-options h3 { font-weight: 700; margin-top: 0; text-transform: uppercase; }
#phase-options h3 > span { background: #f8e314; display: block; height: 45px; line-height: 45px; padding-left: 60px; position: relative; }
#phase-options h3 > span:after { border: 22.5px solid #fff; border-color: #fff #fff transparent transparent; content: ""; position: absolute; right: 0; }
#phase-options h3 ul { background: #0c75ba; color: #fff; height: 45px; margin: 0; padding-left: 45px; }
#phase-options h3 ul:after { border: 22.5px solid #fff; border-color: transparent #fff #fff transparent; content: ""; position: absolute; right: 0; }
#phase-options h3 ul li { display: inline-block; font-size: .7em; font-weight: 700; line-height: 40px; margin: 0; padding: 0; }
#phase-options h3 ul li img { display: inline-block; height: 32px; margin: 0 2px 0 15px; vertical-align: middle; width: auto; }
#phase-options h4 { color: #0c75ba; font-weight: 700; }
#phase-options h5 { color: #212c5d; font-weight: 700; }

#is-maps h3 { background: #f8e314; }
#is-maps h3 span { background: #212c5d; color: #f8e314; display: inline-block; font-weight: 700; margin-right: 12px; padding: 5px 0; text-align: center; width: 118px; }
#is-maps img { width: 100%; }

.remediation-plan { padding: 0 12% !important; }
.remediation-plan h3 { background: #f8e314; font-size: 1.5em; font-weight: 700; height: 36px; line-height: 35px; margin: 0; padding: 0 10px; position: relative; }
.remediation-plan h3:after { border: 18px solid #fff; border-width: 18px 10px; border-color: transparent #fff #fff transparent; content: ""; position: absolute; right: 0; }
.remediation-plan p { padding: 0 12px 16px; }
.remediation-plan img { width: 100%; }

.public-meeting #content > .row { padding: 62px 5% !important; }
.public-meeting .header { margin-bottom: 28px; }
.public-meeting .header:after { border-color: #f8e314 #0c75ba #0c75ba #f8e314; }
.public-meeting #content nav { background: #0c75ba; padding: 6px 8px; text-align: center; }
.public-meeting #content nav ul { margin: 0; padding: 0; }
.public-meeting #content nav li { display: inline-block; margin: 0; padding: 3px 12px; }
.public-meeting #content nav li a { color: #fff; font-weight: 700; }
.public-meeting #content nav li a:hover { color: #ddd; }

.public-meeting #content > .row:first-of-type { overflow: hidden; position: relative; }
.public-meeting #content > .row:first-of-type .col-sm-7 { font-size: 1.2em; padding-right: 9%; }
.public-meeting #content > .row:first-of-type > span { background: #fef9d0; font-size: .9em; font-weight: 700; left: 0; line-height: 1.2em; padding: 10px 28% 10px 6%; position: absolute; top: 0; width: 82%; z-index: -1; }
.public-meeting #content > .row:first-of-type h2 { margin-top: 34px; }
.public-meeting #content > .row:first-of-type .col-sm-5 h2 { margin-bottom: 28px; padding-left: 46px; }
.public-meeting #content > .row:first-of-type:before { background: #eaf2f8; content: ""; height: 100%; position: absolute; right: -7.25%; top: 0%; transform: skew(-14deg); width: 52%; }
.public-meeting #content > .row:first-of-type ul { list-style-type: none; }
.public-meeting #content > .row:first-of-type li { padding-left: 94px; position: relative; }
.public-meeting #content > .row:first-of-type li h3 { font-size: 1.1em; font-weight: 700; margin-bottom: 3px; }
.public-meeting #content > .row:first-of-type li:first-of-type h3 { margin-top: 0; }
/* .public-meeting #content > .row:first-of-type li:first-of-type { margin: 0 0 28px 84px; min-height: 130px; } */
/* .public-meeting #content > .row:first-of-type li:first-of-type div { background: #fff; border-radius: 60px; box-shadow: 0 4px 8px -4px #333; display: block; margin-top: 10px; padding: 7px 10px 9px; } */
.public-meeting #content > .row:first-of-type li:first-of-type div span { color: #212c5d; display: inline-block; font-size: .9em; font-weight: 700; line-height: 1.2em; vertical-align: middle; width: 70%; }
.public-meeting #content > .row:first-of-type li:first-of-type div img { display: inline-block; height: 40px; margin-right: 8px; }
.public-meeting #content > .row:first-of-type li img { width: 70px; }

#welcome { background: #212c5d; color: #fff; margin-bottom: 84px; position: relative; }
#welcome h2 { color: #fff; }
#welcome ul { list-style-type: none; padding-left: 8px; }
#welcome ul li { margin-bottom: 14px; }
#welcome a { color: #fff; font-weight: 700; text-decoration: underline; }

#purpose-and-need .list-var { padding-left: 100px; }
#purpose-and-need .list-var h3 { color: #0c75ba; font-size: 1.4em; font-weight: 700; margin-bottom: 4px; }
#purpose-and-need .list-var p { margin-top: 6px; }
#purpose-and-need .list-var img { width: 80px; }

.public-meeting #content > #environmental-assessment { margin-bottom: 30px; padding: 104px 5% 56px !important; }
#environmental-assessment { position: relative; }
#environmental-assessment:before { background: #eaf2f8; content: ""; height: 100%; left: 0; position: absolute; top: 0; transform: skewY(-3deg); width: 100%; }

#slope-remediation-plan h3 { color: #0c75ba; font-size: 1.4em; font-weight: 700; margin-bottom: 4px; }

.public-meeting #content > #temporary-traffic-control-options { margin-top: 30px; padding: 34px 5% 56px !important; }
#temporary-traffic-control-options { background: #eaf2f8; position: relative; }
#temporary-traffic-control-options:before { background: #eaf2f8; content: ""; height: 20%; left: 0; position: absolute; top: -10%; transform: skewY(-3deg); width: 100%; }
#temporary-traffic-control-options h3 { color: #0c75ba; font-size: 1.4em; font-weight: 700; margin-bottom: 4px; }
#temporary-traffic-control-options .row > div:first-of-type { padding-left: 0 !important; }

#questions { background: #212c5d; color: #fff; position: relative; }
#questions h2 { color: #fff; }
#questions a { color: #fff; font-weight: 700; }
#questions a:hover { color: #ddd; }

#blue-triangle { margin-bottom: 14px; }
#blue-triangle img { width: 100%; }

.public-meeting #content > .row:last-of-type { padding: 0 6% 64px!important;  }
.public-meeting #content > .row:last-of-type h3 { color: #212c5d; font-weight: 700; margin-bottom: 24px; }

#want-hear-you > p { color: #212c5d; font-size: 1.1em; }
.yay-link { background: #f8e314; border-radius: 100px; color: #212c5d; display: inline-block; font-size: 1.2em; font-weight: 700; margin: 24px 0 20px;  padding-left: 24px; }
.yay-link:hover { background: #ddc905; color: #212c5d; }
.yay-link img { height: 46px; margin-left: 12px; }
#comments-by-mail p:last-of-type { margin-left: 3%; }

.basic-button { background: #212c5d; border-radius: 50px; color: #fff; display: inline-block; font-weight: 700; margin-top: 12px; padding: 5px 18px; }
.basic-button:hover { background: #0a0f28; color: #fff; }

form label { left: -9999px; position: absolute; }
form div { float: left; margin-right: 3%; width: 48.5%; }
form div:last-of-type { margin-right: 0; }
form input[type="text"] { background: #e5e6eb; border: 0; font-size: 1.2em; padding: 4px 9px; }
form textarea { background: #e5e6eb; border: 0; font-size: 1.2em; height: 160px; margin-top: 24px; padding: 4px 9px; }
form input[type="submit"] { background: #212c5d; border-radius: 80px; float: right; font-weight: 700; padding: 10px 30px; }
form input[type="submit"]:hover { background: #131c45; }

.thanks-msg { color: #0c75ba; display: none; font-size: 1.2em; font-weight: 700; text-align: right; }

.contact-page a { color: #000; font-weight: 700}
.contact-page a:hover { color: #333; }
.contact-page .list-var a { display: inline-block; font-size: 1.3em; font-weight: 700; margin-top: 28px; }
.contact-page h3 { color: #0c75ba; font-weight: 700; margin-bottom: 18px; padding-left: 1.5%; }

.footer { background: #212c5d; padding: 15px 6.5% 20px; }
.footer img { height: 108px; }
.footer img[src*="fhwa"] { height: auto; margin-left: 28px; width: 230px; }
.footer img:last-of-type { float: right; }

.photo-row { display: flex; flex-wrap: wrap; justify-content: space-between; list-style: none; margin-top: 30px; padding: 0; }
.photo-row li { margin-bottom: 18px; width: 23%; }

/* Lightbox */
.showing-hdr-lightbox { overflow: hidden; }
.hdr-lightbox img { width: 100%; }
.hdr-lightbox a { display: block;}
.hdr-lightbox > button { background-color: rgba(0,0,0,.75); border: 0; cursor: pointer; display: none; height: 0; left: -9999px; margin: 0; position: absolute; top: 0; transition: 0s; width: 100%; }
.hdr-lightbox button span { left: -9999px; position: absolute; }
.hdr-lightbox > div { top: 80px; }
.hdr-lightbox > div .hdr-close-lightbox { background: 0; border: 0; font-size: 3em; display: none; line-height: 1em; position: fixed; right: 14px; top: -4px; }
.hdr-lightbox.enhanced { height: 100%; left: 0; position: fixed; top: 0; width: 100%; z-index: 5555; }
.hdr-lightbox.enhanced > button { display: block; height: 100%; left: 0; transition: height .6s, left 0s; }
.hdr-lightbox.enhanced > div { background-color: #fff; border: 1px solid #333; box-shadow: 4px 13px 28px 0 #111; left: 6%; margin: 0; max-height: 80%; overflow: auto; position: absolute; top: 40px; transition: .8s; width: 86%; }
.hdr-lightbox.enhanced > div .hdr-close-lightbox { display: block; }

/*********************************************/
/****** Media Queries ************************/
/*********************************************/
/* Add more queries as needed; 992px is the column breakpoint for "medium"  columns in Bootstrap */

@media screen and (min-width: 1720px) {
    html, body { font-size: 20px; }
    .header h1 { width: 360px; }
    .header .nav { margin-top: 26px; }

    .map h2 { height: 60px; line-height: 60px; }
    .map h2:after { border-width: 30px; }

    #phase-options h3 ul { line-height: 24px; }
    #is-maps h3 span { width: 148px; }
}

@media screen and (max-width: 1420px) {
    #is-maps h3 { font-size: 1.3em; }

    .remediation-plan { padding: 0 8% !important; }
    .remediation-plan h3 { font-size: 1.3em; }
}

@media screen and (max-width: 1250px) {
    .public-meeting #content > .row:first-of-type:before { transform: skew(-8deg); }
/*     .public-meeting #content > .row:first-of-type li:first-of-type { margin: 0 0 28px 54px; min-height: 130px; } */
    .public-meeting #content > .row:first-of-type li p { line-height: 1.2em; }
}

@media screen and (max-width: 1150px) {
    .header { padding-right: 3%; }
    .header h1 { font-size: 1.6em; }
    .header .nav { font-size: .9em; margin-top: 15px; }

    #phase-options .col-sm-6 { margin-bottom: 34px; width: 100%; }
    #is-maps h3 { font-size: 1.1em; }
    #is-maps h3 span { width: 90px; }

    .remediation-plan { padding: 0 5% !important; }
    .remediation-plan h3 { font-size: 1em; }

    .contact-page .list-var { padding: 0; text-align: center; }
    .contact-page .list-var img { display: block; margin: 0 auto; position: static; }
    .contact-page .list-var a { margin-top: 12px;  }
}

@media screen and (max-width: 992px) {
    h1 { font-size: 2.2em; margin: 20px 0 6px; }
    h2 { font-size: 1.7em; margin: 12px 0 0; }
    h3 { font-size: 1.4em; margin: 20px 0 0; }
    h4 { font-size: 1.3em; margin: 28px 0 0; }
    h5 { font-size: 1.2em; margin: 26px 0 0; }
    h6 { font-size: 1.1em; margin: 26px 0 0; }
    p, li { font-size: .9em; line-height: 1.3em; }
    .button { font-size: .8em; border-radius: 12px; padding: 4px 12px 3px; }
    table tr { font-size: .8em; padding: 2px; }
    .vertical-center > div { margin: 0; }

    /* Quick Mobile Menu */
    #mobile-menu { display: inline-block; }
    .header { padding: 12px 18px; }
    .header h1 { font-size: 1.5em; width: 230px;}
    .header .nav { margin-top: 13px; }
    .header .nav ul { background-color: #0c75ba; box-shadow: 2px 4px 8px -4px #000; display: none; opacity: 0; padding: 0; position: absolute; right: 110%; top: 60px; width: 236px; z-index: 1; }
    .header .nav ul li { padding: 6px 0 7px; }
    .header .nav > ul > li:first-of-type { border-top: 0; padding-bottom: 0 !important; }
    .header .nav ul ul { border: 0; box-shadow: none; display: block !important; margin: 6px 0 0; padding: 0; position: static; width: 100%; }
    .header .nav ul ul li { border-top: 1px solid #fff !important; padding: 6px 0 7px !important; }
    .header .nav ul ul li a { font-size: 1.4em; font-weight: 400; }
    .menu-opened .header .nav ul { opacity: 1; right: 0; transition: right 0s, opacity .2s; }
    .header .nav li { border-top: 1px solid #fff; display: block; margin: 0; padding: 8px 4px; text-align: center; }
    .header .nav ul li.active a:after { display: none; }

    .container { padding-bottom: 114px; }
    #content > .row { padding: 18px 4% 28px; }

    .map h2 { height: 40px; line-height: 40px; padding-left: 5.5%; }
    .map h2:after { border-width: 20px; }
    .map > div { overflow: auto; width: 100%; }
    .map img { max-width: 800%; width: 1000px; }

    #env-assessment-list .list-var { min-height: 70px; padding-left: 80px; }
    #env-assessment-list li img { width: 60px; }

    #is-maps > div { padding: 0 !important; }

    .public-meeting #content > .row { padding: 26px 3% 38px !important; }
    .public-meeting #content > .row:first-of-type .col-sm-7 { font-size: 1.1em; }
    .public-meeting #content > .row:first-of-type h2 { font-size: 1.4em; margin-top: 70px; }
    .public-meeting #content > .row:first-of-type:before { transform: skewX(-12deg); }
    .public-meeting #content > .row:first-of-type li { padding-left: 50px; }
    .public-meeting #content > .row:first-of-type li img { width: 38px; }
/*     .public-meeting #content > .row:first-of-type li:first-of-type { padding-left: 21px; } */
    .public-meeting #content > .row:first-of-type li:first-of-type div span { line-height: 1em; width: 65%; }
    .public-meeting #content > .row:first-of-type li:first-of-type div img { height: 32px; }

    .contact-page .list-var img { width: 44px; }
    .contact-page .list-var a { font-size: 1.1em; margin-top: 8px;  }

    #top-row div:last-of-type { width: 100%; }
    
    .hdr-lightbox > div .hdr-close-lightbox { font-size: 2em; right: 8px; }
    .hdr-lightbox.enhanced img { max-width: 800%; width: 260%; }

    .footer { height: 114px;padding: 14px 4% 18px; }
    .footer img { height: 72px; }
    .footer img[src*="fhwa"] { margin-left: 18px; width: 170px; }
}

@media screen and (max-width: 768px) {
    .public-meeting #content > .row:first-of-type .col-sm-7 { font-size: 1em; }
    .public-meeting #content > .row:first-of-type ul { padding-left: 0; }
    .public-meeting #content > .row:first-of-type li { padding-left: 50px; }
    .public-meeting #content > .row:first-of-type li:before { height: 30px; width: 30px; }
    .public-meeting #content > .row:first-of-type li:first-of-type { margin: 0 0 24px; min-height: 0;  }
/*     .public-meeting #content > .row:first-of-type li:first-of-type div { max-width: 300px; } */
    .public-meeting #content > .row:first-of-type h2 { margin-top: 30px; padding-left: 0 !important; }
    .public-meeting #content > .row:first-of-type > span { display: block; padding: 6px 18px; position: relative; width: 100%; z-index: 0; }

    .public-meeting #content > #environmental-assessment { padding-top: 70px !important; }

    #progress { font-size: 1.4em; }

    #temporary-traffic-control-options:before { top: -2%;  }
}

@media screen and (max-width: 620px) {
    .map img { width: 820px; }    
    .container { padding-bottom: 146px; }
    
    .footer { height: 146px; padding: 10px 18px 14px; text-align: center; }
    .footer img { height: 60px; }
    .footer img[src*="fhwa"] { margin-left: 18px; width: 120px; }
    .footer img:last-of-type { display: block; margin: 0 auto; float: none; }

    .public-meeting #content > #welcome { margin-bottom: 70px; padding-bottom: 56px !important; }

    #phase-options .list-var { margin-left: -20px !important; }
    #phase-options > div { padding-left: 34px !important; }
    #phase-options h3 ul { height: auto; padding-right: 12px; }
    #phase-options h3 span:after,
    #phase-options h3 ul:after { display: none; }
    #phase-options h4 { margin-top: 12px; }

    .yay-link { border-radius: 8px; font-size: .85em; padding: 4px 9px; }
    .yay-link img { display: none; }

    .photo-row li { margin-bottom: 18px; width: 46%; }
}