/* TYPE DEFINITIONS ------------------------------------------------------ */
@font-face {
    font-family: 'DIN-Bold';
    src: url('fonts/DIN-Bold.eot');
    src: url('fonts/DIN-Bold.eot?#iefix') format('embedded-opentype'),
        url('fonts/DIN-Bold.woff') format('woff'),
        url('fonts/DIN-Bold.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'DIN-Regular';
    src: url('fonts/DIN-Regular.eot');
    src: url('fonts/DIN-Regular.eot?#iefix') format('embedded-opentype'),
        url('fonts/DIN-Regular.woff') format('woff'),
        url('fonts/DIN-Regular.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'DIN-Light';
    src: url('fonts/DIN-Light.eot');
    src: url('fonts/DIN-Light.eot?#iefix') format('embedded-opentype'),
        url('fonts/DIN-Light.woff') format('woff'),
        url('fonts/DIN-Light.ttf') format('truetype');
    font-style: normal;
}

/* horizontal section dividers */
hr {
    border-top: #ddd 1px solid;
    margin-top: 40px;
}

br {
    display: block;
    margin-top: 10px;
}

/* a:hover {
    color: #CCC !important;
    text-decoration: none;
} */

/* TYPE SIZES ------------------------------------------------------ */
/* 30pt */
.lg-txt {
    font-family: Inter, DIN-Light,"Helvetica Neue",Helvetica,Arial,sans-serif;
    color: #4F5357;
    letter-spacing: 2px;
    font-size: 30pt;
}

/* Bold 30pt */
.lg-txt-bold {
    font-family: Inter, DIN-Bold,"Helvetica Neue",Helvetica,Arial,sans-serif;
    color: #4F5357;
    letter-spacing: 2px;
    font-size: 30pt;
    font-weight: 600;
}

/* All-caps 16pt */
.md-txt {
    font-family: Inter, DIN-Bold,"Helvetica Neue",Helvetica,Arial,sans-serif;
    color: #4F5357;
    letter-spacing: 2px;
    font-size: 14pt;
    text-transform: uppercase; /* capitalize all letters */
    font-weight: 600;
}

.sm-txt {
    font-family: Inter, DIN-Regular,"Helvetica Neue",Helvetica,Arial,sans-serif;
    color: #4F5357;
    letter-spacing: 0.4pt;
    font-size: 10pt;
    line-height: 18pt;
}

.sm-txt-caps {
    font-family: Inter, DIN-Regular,"Helvetica Neue",Helvetica,Arial,sans-serif;
    color: #4F5357;
    letter-spacing: 1.4pt;
    font-size: 11pt;
    line-height: 20pt;
    text-transform: uppercase;
}

.xs-sm-txt {
    font-family: Inter, DIN-Regular,"Helvetica Neue",Helvetica,Arial,sans-serif;
    color: #4F5357;
    letter-spacing: 0.4pt;
    font-size: 10pt;
    line-height: 14pt;
}

/* 9 pt */
.xs-txt {
    font-family: Inter, DIN-Regular,"Helvetica Neue",Helvetica,Arial,sans-serif;
    color: #4F5357;
    letter-spacing: 0.4pt;
    font-size: 9pt;
    line-height: 12pt;
}

/* All-caps 9 pt */
.xs-txt-caps {
    font-family: Inter, DIN-Regular,"Helvetica Neue",Helvetica,Arial,sans-serif;
    color: #4F5357;
    letter-spacing: 0.4pt;
    font-size: 9pt;
    line-height: 12pt;
    text-transform: uppercase;
}

.xs-txt-nav, .xs-txt-footer {
    font-family: Inter, DIN-Regular,"Helvetica Neue",Helvetica,Arial,sans-serif;
    color: #4F5357;
    letter-spacing: 0.4pt;
    font-size: 9pt;
    line-height: 20pt;
}

/* TOP NAV ------------------------------------------------------ */
.navbar {
    border-radius: 0;
    border-bottom: #4F5357 1px solid;
    background-color: #FFF;
}

@media only screen and (min-width: 767px) {
    .nav-top {
        display: none;
    }
}

/* SIDEBAR NAV ------------------------------------------------------ */

.main {
    margin-left: 18%; /* Same as the width of the sidebar */
    padding: 0px 10px;
}

.nav {
    position: fixed;
    height: 100%;
    top: 0px;
    left: 0px;
    width: 18%;
}

.nav img {
    position: relative;
    width: 100%;
    top: 80px;
}

.nav-text-top {
    position: relative;
    left: 10%;
    top: 60px;
}

.nav-text-bottom {
    position: relative;
    left: 10%;
    top: 100px;
}

.active {
    font-family: Inter, DIN-Bold,"Helvetica Neue",Helvetica,Arial,sans-serif;
    font-weight: 600;
}

a, a:hover, a:active, a:visited, a:focus {
    text-decoration: none;
}

.nav-sections {
    position: fixed;
    left: 3%;
    top: 200px;
    /* opacity: 0; */
}

#vertical-bar {
    position: fixed;
    left: 30px;
    top: 0px;
    background: #4F5357;
    width: 7px;
    height: 300px;
    z-index: 100;
}

@media only screen and (max-width: 767px) {
    .nav-sidebar {
        display: none;
    }
}

/* TITLE & WELCOME ------------------------------------------------------ */
.title {
    margin-top: 150px;
}

.button {
    background-color: #4F5357;
    border: none;
    color: #FFF;
    padding: 10px 10px;
    margin: 20px 20px 20px 0px;
    line-height: 50pt;
    text-decoration: none;
}

.reverse-button {
    background: 0;
    border: #4F5357 1px solid;
    color: #4F5357;
    padding: 10px 10px;
    margin: 20px 20px 20px 0px;
    text-decoration: none;
}

.award-button {
    /* background: #DAE6FA; */
    background: #eee09e;
    font-size: 10px;
    color: #4F5357;
    padding: 3px 7px;
    margin-left: 5px;
    border-radius: 8px;
    text-decoration: none;
}

.button:hover, .reverse-button:hover {
    background-color: #CCC;
    text-decoration: none;
}
.button:hover, .button:focus {
    color: #FFF;
    text-decoration: none;
}
.reverse-button:hover, .reverse-button:focus {
    color: #4F5357;
    text-decoration: none;
}

.welcome {
    padding-bottom: 75px;
}

.pub-img img {
    max-width: 200px;
}

/* SECTIONS ------------------------------------------------------ */
.section {
    padding-top: 75px;
}

.section-title {
    margin-bottom: 40px;
}

.intro-section0 {
    padding-right: 25px;
}

.intro-section1 {
    padding-right: 25px;
    /*padding-left: 0px;*/
}

@media only screen and (max-width: 767px) {
    .intro-section0 {
        padding-right: 15px;
    }

    .intro-section1 {
        padding-left: 15px;
    }
}

/* ITEMS ------------------------------------------------------ */
.items img {
    width: 100%;
    opacity: 1;
    /*margin-bottom: 40px;*/
    transition: opacity .25s ease-in-out;
    -moz-transition: opacity .25s ease-in-out;
    -webkit-transition: opacity .25s ease-in-out;
}

.items img:hover {
    opacity: 0.3;
}

.items-row {
    margin-bottom: 40px;
}

.items-description {
    padding-left: 15px;
}

/* bottom of section within item descriptive text */
.items .full-item {
    margin-bottom: 30px;
    margin-top: 15px;
}

/* links within item descriptive text */
.items .sm-txt a, .items .xs-txt a, .items .sm-txt-caps a {
    color: #75a0ea;
}

.xs-txt a, .sm-txt a, .md-txt a, .xs-sm-txt a, .xs-txt-nav a {
    color: #4F5357;
}

.sm-txt a:hover, .xs-txt-nav a:hover, .items .sm-txt-caps a:hover, .items .sm-txt a:hover, .items .xs-sm-txt a:hover, .items .xs-txt a:hover  {
    color: #CCC !important;
    text-decoration: underline;
}

/* MODALS */
.modal-content {
    border: none;
    border-radius: 0;
    box-shadow: none;
    padding: 20px 40px;
}

.item-detail {
    margin-top: 40px;
}

.modal-body img {
    width: 100%;
    margin-top: 40px;
}

.modal.fade .modal-dialog {
    -webkit-transition: none;
    -o-transition: none;
    transition: none;
    webkit-transform: none;
    -ms-transform: none;
    -o-transform: none;
    transform: none;
}

/* FOOTER */
.footer {
    margin-top: 75px;
    padding-top: 40px;
    padding-bottom: 40px;
    border-top: #ddd 1px solid;
}

/* TABS */
.main-tab {
    overflow: hidden;
    padding-top: 10px;
    padding-bottom: 10px;
}
.main-tab button {
    float: left;
    background-color: #fff;
    border: #fff 1px solid;
    outline: none;
    cursor: pointer;
    padding: 3px 15px;
    margin: 5px;
    border-radius: 25px;
    font-size: 12px;
}

.main-tab button.active {
    background-color: #ddd;
}

.main-tab button:hover {
    background-color: #ddd;
}

/* ACCORDIONS ----------------------------------------------- */
.accordion>input[type="checkbox"] {
    position: absolute;
    left: -100vw;
}

.accordion .content {
    overflow-y: hidden;
    height: 0;
    transition: height 0.3s ease;
}

.accordion>input[type="checkbox"]:checked~.content {
    height: auto;
    overflow: visible;
}

.accordion label {
    display: block;
}

.handle label {
    font-weight: normal;
}

pre {
    font-size: 10px;
    display: block;
    overflow-x: scroll;
}

.pub-abs {
    display: block;
    padding: 15px;
    margin: 10px 0 0 0;
    line-height: 1.6;
    color: #333;
    background-color: #f5f5f5;
    border: 1px solid #ccc;
    border-radius: 4px;
}

.pub-tldr {
    font-style: italic;
    margin-bottom: 5px;
    font-size: 7pt;
}

.pub-link {
    display: inline-block;
}

.pub-links {
    margin-top: 5px;
}
