﻿/* ML: This is CSS that isn't avail in Finn master, so anything additional CSS needed, I'm putting in here */

form {
    margin-block-end: 0;
}

a {
    cursor: pointer;
}

a > i {
    width: 26px;
}

/*button.small {
    font-size: 14px !important;
}*/
.chart-responsive {
    width: 100%;
    min-height: 450px;
}
.chart-responsive-half {
    width: 50%;
    min-height: 450px;
}

.hero.hero-short .blurb {
    padding: 30px calc(50% - 576px);
    padding-top: 35px;
    padding-bottom: 1rem;
}
.hero.hero-short {
    min-height: 120px;
    background-color: #283359;
}

.page-wrap .hero .crumb {
    top: 1rem;
}

h1 {
    font-family: Geogrotesque;
    font-size: 3.5rem;
    font-weight: 600;
}

h5 {
    font-size: 18px;
    margin: 0 0 8px 0;
}

.blocker {
    z-index:200;
}

.green {
    color: #3e7b25;
}

.avatar img {
    border-radius:50%;
}
.avatar.leaderboard a:first-child:after {
    bottom: 25px;
}

.page-wrap .site-header > div.join .button:after {
    content: '';
    position: absolute;
    right: 12px;
    top: 12px;
    width: 14px;
    height: 19px;
    font-size: 17px;
    background: url(/images/join-icon.svg) center center no-repeat;
    background-size: contain;
    transform: rotate(0deg);
}

::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
    color: #999;
    opacity: 1; /* Firefox */
}

:-ms-input-placeholder { /* Internet Explorer 10-11 */
    color: #999;
}

::-ms-input-placeholder { /* Microsoft Edge */
    color: #999;
}

.content-with-right-details .button:hover, .button.light-blue:hover {
    background-color: #f2f3f5;
    border: 1px solid rgba(66, 80, 114, .8);
    color: #868789 !important;
    text-decoration: none !important
}

/*.content-with-callouts .content p {
    font-size: 16px;
}*/


.expandable-box .expanded-content blockquote {
    font-size: 18px;
    margin-top: 0;
}


.site-nav {
    background-color: #425072;
    padding: 0;
    /*overflow: hidden;*/
    z-index: 9;
}

    .site-nav > div {
        display: flex;
        padding: 16px calc(50% - 570px);
    }

.page-wrap .site-nav.compressed {
    padding-top: 9px;
    padding-bottom: 9px;
}

.page-wrap .site-nav.stuck {
    position: absolute;
    top: 119px;
    left: 0;
    width: 100%;
}

@media (min-width: 0em) and (max-width: 48em) {

    .page-wrap .site-nav.stuck {
        display: none;
    }
}

.site-nav-dropdown {
    position: relative;
}

.site-nav-main-group {
    font-family: "Geogrotesque Cond W01 Medium";
    color: #fff;
    padding: 16px 1rem;
    font-size: 20px;
}

    .site-nav-main-group:hover,
    .site-nav-dropdown:hover .site-nav-main-group {
        background-color: #fff;
        color: #425072;
        text-decoration: none;
    }

        .site-nav-main-group:hover + .site-nav-drop-content {
            display: block;
        }

.site-nav-drop-content {
    display: none;
    position: absolute;
    top: 38px;
    background-color: #fff;
    color: #333;
    min-width: 500px;
    min-height: 200px;
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
    z-index: 10;
}

    .site-nav-drop-content:hover {
        display: block;
    }


.site-nav-drop-content-container a {
    color: #425072 !important;
}

.site-nav-drop-content-container {
    display: flex;
    padding: 2rem;
}

    .site-nav-drop-content-container > :not(:first-child) {
        padding-left: 2rem;
    }

    .site-nav-drop-content-container > div > ul {
        /*margin-left: 30px;*/
    }

        .site-nav-drop-content-container > div > ul > li {
            line-height: 2rem;
            white-space: nowrap;
        }

            .site-nav-drop-content-container > div > ul > li > a {
                color: #425072;
            }

                .site-nav-drop-content-container > div > ul > li > a:hover {
                    text-decoration: underline;
                }

.site-nav-drop-content-highlight {
    min-width: 150px;
    border-left: 1px solid #425072;
    margin-left: 2rem;
}

    .site-nav-drop-content-highlight > a {
        text-align: center;
    }

        .site-nav-drop-content-highlight > a > div > i {
            font-size: 40px;
        }

.site-nav-drop-header {
    color: #868789;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 8px;
    white-space: nowrap;
}

    .site-nav-drop-header > a > i {
        width: 32px;
    }

.compressed-nav {
    top: 66px !important;
    position: fixed !important;
}



.fade-visible {
    display: inline-block !important;
    opacity: 1;
    transition: opacity 2s linear;
}

.fade-hidden {
    display: none;
    opacity: 0;
    transition: display 0s 2s, opacity 2s linear;
}

.page-wrap .content ul li {
    padding-bottom: 0.5rem;
    margin-left: 2rem;
    list-style: disc;
}

.membership-form ul.error li {
    color: red;
}

.button.cart:after, input[type=button].cart:after, .button.download:after, input[type=button].download:after {
    content: none;
}
.membership-form div.half {
    float: left;
    width: 50%;
    padding-right: 20px;
    clear: none;
}
/*.membership-form div {
    padding: 0 20px 9px 0;
    width: 100%;
    clear: both;
}*/
.membership-form div.half input {
    min-width: 1px;
    width: 100%;
}

.membership-form a:not(.button) {
    color: #0091CA;
    font-size: unset;
}

@media (max-width: 48em) and (min-width: 0em) {

    h3 {
        font-size: 26px;
        margin: 0;
    }

    .hero.hero-short {
        min-height: 80px !important;
    }

    .hero .blurb {
        margin: 0;
        padding: 0 !important;
    }

    .page-wrap .hero .blurb h1 {
        font-size: 32px;
        padding: 0 13px;
        margin-top: 30px;
        padding-bottom: 10px;
        z-index: 1;
    }

    .membership-form div.half {
        width: 100%;
        padding-right: 0;
    }

    .pair-info {
        width: 100%;
        margin-bottom: 0.8rem;
    }
        .pair-info .first {
            width: 65px;
            padding-right: 14px;
            margin-left: 2rem;
            text-align: right;
        }
}

.pair-full > div {
    display: flex;
    margin-bottom: 1rem;
}
    .pair-full > div > h5 {
        min-width: 100px;
    }
    .pair-full > div > div {
        width: 100%;
    }


.pair-info {
    display: flex;
    padding-top: 6px;
}
    .pair-info .first {
        width: 65px;
        padding-right: 14px;
        text-align: right;
    }

    .pair-info .second {
        font-weight: 600;
    }

.padding-small td {
    padding-bottom: 2px;
}

.pairs span {
    font-size: 16px;
}

.select-wrapper {
    position: relative;
}

.select-wrapper:before {
    content: '\f078';
    font-family: FontAwesome;
    color: #868789;
    display: inline-block;
    position: absolute;
    right: 0;
    top: 2px;
    pointer-events: none;
    border-left: 1px solid #868789;
    z-index: 2;
    padding: 12px 12px 0 12px;
    height: 25px;
    font-size: 12px;
}
.button.light-blue, input[type=button].light-blue {
    font-weight: 400;
}

.section-level-up .button.small.light:hover,
.section-level-up .button.small.light:active,
.section-level-up .button.small.light:focus/*,
.button:hover,
.button:active,
.button:focus*/ {
    background: #f2f3f5;
    color: #868789 !important;
}
.section-level-up {
    z-index: 0;
}

.titles td:first-child a {
    font-weight: 400;
    font-size: 18px;
    overflow-wrap: break-word;
}

.titles td a {
    text-decoration: none;
}

.table-row td {
    vertical-align: top;
}

.titles {
    /*border-left: 1px solid #cbccd0;
    border-right: 1px solid #cbccd0;*/
    border: 0;
    width: 100%;
    border-spacing: 0;
}

.titles td, .titles th {
    border-left: none;
    max-width: 600px;
}
.titles th a:after {
    content:none;
}

.titles.grouped td {
    border: none;
}

[type=checkbox]:not(:checked) + label:after, [type=checkbox]:checked + label:after {
    content: '\f00c';
    font-family: FontAwesome;
}
textarea {
    padding: 18px !important;
    color: #4a4a4a;
    font-size: 16px;
    font-family: Geogrotesque Cond W01 Regular, Helvetica Neue, Helvetica, Roboto, Arial, sans-serif;
    -webkit-appearance: none;
    line-height: 20px !important;
    background: #fff;
    border: 1px solid #cbccd0;
    /*padding: 0.5rem 1rem;*/
    border-radius: 5px;
    min-height: 80px;
    min-width: 350px;
    width: 100%;
}
iframe {
    overflow: auto;
}
figure h5 {
    color:#fff !important;
}

.page-wrap input:not(.button) {
    background: #fff;
    border: 1px solid #cbccd0;
}
@media (max-width: 48em) and (min-width: 0em) {
    .page-wrap input:not(.button), .site-header input[type=text], .site-wrap textarea, .site-wrap select, textarea {
        min-width: 1px;
        width: 80% !important;
    }
    .page-wrap {
        min-height: 90vh;
    }
}
@media (max-width: 48em) and (min-width: 0em) {
    body {
        font-size: 100%;
    }
}
@media (min-width: 48em) {
    .total {
        width: 40%;
    }
}

@media only screen and (max-width: 600px) {
    .titles td:first-child {
        padding: 0.5rem;
    }
}

p.error-v2 label {
    color: red;
}

p.error {
    /*min-height: 88px;*/
}

p.error span {
    color: red;
    font-size: 16px;
}

    p.error label::after {
        content: ' *'
    }

p.error span:not(.select2-selection):not(.selection):not(.select2-selection__rendered) {
    float: right;
}

.membership-form p span:not(.select2-selection):not(.selection):not(.select2-selection__rendered) {
    color: red;
    float: right;
}
.form-dropdown {
    min-height: 5.5rem;
}

.flex-columns {
    display: flex;
    flex-wrap: wrap;
    clear:both;
}
.flex-columns div.column {
    margin: 1rem;
}
.flex-columns div.column-6 {
    width:50%;
    padding: 0 1rem 0 0;
}

@media (max-width: 38em) and (min-width: 0em) {
    .flex-columns {
        display: flex;
        flex-wrap: wrap;
    }

    .flex-columns div.column {
        margin: 1rem;
    }

    .flex-columns div.column-6 {
        width: 100%;
        padding: 0;
    }
}

.checkbox-unset input {
    left: auto !important;
    position: static !important;
    min-width: unset !important;
    padding: 0 !important;
    line-height: normal !important;
    height: unset !important;
    -webkit-appearance: checkbox !important;
    -moz-appearance: checkbox !important;
}

.private-forum .logo {
    margin: 0 18px 0 0;
    height: 85px;
    width: 154px;
    background-position: right;
    background-size: contain;
    background-repeat: no-repeat;
}

ul.star-ratings li:before {
    content: none;
    font-family: FontAwesome;
    font-size: 5px;
    position: absolute;
    left: -1rem;
    top: 10px;
    color: #4a4a4a;
}

ul.star-ratings li {
    display: inline-block;
    margin: 0;
}

.modal {
    height: 70%;
    max-height: 820px;
    max-width: 850px;
}

.modal-login {
    height: 70%;
    max-height: 430px;
    max-width: 380px;
    padding: 15px;
}

.tabs-cards > ul > li:not(.tab-content) a {
    font-size: 1.5rem;
}

.tabs-cards > ul > li:not(.tab-content):not(.active) a {
    height: 90%;
}

.page-wrap ul li a.button:not(.outline) {
    color: #fff;
}

.tabs-header .nsta-tabs {
    margin: 0;
    display: flex;
    justify-content: center;
    padding-bottom: 18px;
    padding-top: 18px;
    padding: 0;
}

.page-wrap ul li:before {
    content: none;
}

.page-wrap .nsta-tabs li {
    list-style-type: none;
    margin: 0;
    /*font-size: 1.5em;*/
    min-width: 100px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    margin: 0 10px -3px;
}

.page-wrap .nsta-tabs li a {
    font-family: Geogrotesque Cond W01 Medium,Helvetica Neue,Helvetica,Roboto,Arial,sans-serif;
    font-weight: 400;
    color: #0091ca;
    padding: 18px 27px 21px;
    display: block;
    text-align: center;
    line-height: 1.1;
    background-color: #f2f3f5;
    border-radius: 9px 9px 0 0;
    color: #868789;
    box-shadow: inset 0 -9px 9px -9px rgba(0,0,0,.25), 0 0 9px 0 rgba(0,0,0,.15);
}

.page-wrap .nsta-tabs li.active a {
    background: #fff;
    border-radius: 9px 9px 0 0;
    color: #fe991f;
    box-shadow: 0 0 9px 0 rgba(0,0,0,.15);
}

.mini-tabs {
    margin-left: 0;
    list-style: none;
    border-bottom: 0.0625rem solid #ddd;
    padding: 16px 0 !important;
    margin-bottom: 1.5rem !important;
    display: flex;
    flex-wrap: nowrap;
    width: 100%;
    overflow-x: auto;
}

    .mini-tabs li {
        display: inline-block;
        margin-left: 0 !important;
        white-space: nowrap;
    }

    .mini-tabs .active a {
        color: #7d8386;
        border-bottom: 2px solid;
    }

.mini-tabs a {
    font-size: 1.125rem;
    padding: 16px;
}

.mini-tabs li:before {
    content: none;
    left: unset;
}
.mini-tabs li + li {
    margin-left: 0.5rem;
}
.mini-tabs li + li:before {
    display: inline-block;
    /*content: '|';*/
    font-weight: bold;
    margin-right: 0.75rem;
    color: #7d8386;
    position: relative;
    top: -0.125rem;
    font-size:18px;
    left:unset;
}

.heading-helper {
    display: block;
    font-size: 16px;
    font-style: italic;
    font-weight:400;
}

.panel {
    border-style: solid;
    border-width: 0;
    border-color: #e2e2e2;
    margin-bottom: 1.25rem;
    padding: 2rem;
    background: #fefefe;
    color: #575655;
}
.panel {
    position: relative;
    background: #e2ecef;
}

.info-prompt {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
}

.info-prompt .content p {
    padding:0 2rem 0 0;
}

.dropdown-async {
    border: 1px solid #cbccd0;
    background: #fff;
    height: 50px;
    border-radius: 5px;
    -moz-border-radius: 5px;
    padding: 0 18px; 
    font-size: 16px;
    color: #4a4a4a;
    font-weight: 400;
    text-transform: none;
    text-align: left;
    width: 100%;
    font-family: Geogrotesque Cond W01 Regular,Helvetica Neue,Helvetica,Roboto,Arial,sans-serif,HelveticaNeueETW01-55Rg;
}

.expandable-box {
    background: #f5f5f5;
    border: 0;
}

/*.button.close {
    padding-left: 0.625rem;
    padding-right: 0.625rem;
    font-size: 1rem;
    line-height: 1rem;
    position: absolute;
    right: 1rem;
    top: 1rem;
}*/

/*.button.small.close, input[type=button].small.close {
    padding: 10px 30px 10px 4px;
}*/

/*@font-face {
    font-family: rubik;
    src: url(../fonts/Rubik-Regular.eot);
    src: url(../fonts/Rubik-Regular.eot?#iefix) format('embedded-opentype'), url(../fonts/Rubik-Regular.woff) format('woff'), url(../fonts/Rubik-Regular.ttf) format('truetype'), url(../fonts/Rubik-Regular.svg#slick) format('svg')
}*/

.long-form, .long-form p, .long-form li, .forum-list td.post p, .forum-list td.response p {
    font-family: "Rubik-Light", "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
    font-weight: 300;
    font-size: 16px;
    line-height: 2;
}

.forum-list td:first-child a {
    font-weight: 400;
}
.link-disabled {
    /*z-index: -1; Make it not clickable*/
    position: relative;
    opacity: .5; /*Lighter*/
}

.mce-btn .mce-txt {
    color:inherit !important;
}
/*.mce-btn-group .mce-btn, .mce-container * {
    width: auto !important;
    padding: 0 !important;
}
.mce-btn button {
    padding: 4px 6px !important;
}*/


/*  #Mobile (Portrait)
        ================================================== */
/* Note: Design for a width of 320px */
@media all and (max-width: 479px) {
    td.col_4, th.col_4 {
        display: none !important;
        width: 0;
        height: 0;
        opacity: 0;
        visibility: collapse
    }

    .titles td, .titles th {
        max-width: 95vw !important;
    }

    .stats td, .stats th {
        display: inline-block;
        padding: 0.5rem 1rem;
    }
    .stats td:first-child {
        padding: 0.5rem;
        width: 100%;
        padding: 9px 9px 0;
        border-top: 1px solid #cbccd0;
    }
    .stats td:first-child div {
        position: static !important;
        display: inline-block;
        vertical-align: top;
    }

}


/* BEGIN: Special forms - login, forget pass, etc - ML 12-11-2019 */
.membership-form p.half-clear {
    float: left;
    width: 50%;
    padding-right: 20px;
    clear: both;
}

@media(min-width:0em) and (max-width:48em) {
    .membership-form p.half-clear {
        width: 100%;
        padding-right: 0
    }
}

.membership-form p.half-clear input {
    min-width: 1px;
    width: 100%
}
/* END: Special forms */


/* BEGIN Dashboard Stuff */
.badge-list {
    list-style: none;
    margin-left: -2%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: left;
    -webkit-justify-content: left;
    -ms-flex-pack: left;
    justify-content: left;
}

ul.badge-list li:before, ul.dashboard-nav li:before, ul.featured-profiles li:before, ul.mini-profile-grid li:before {
    content: none;
}

ul.badge-list li {
    margin-left:0.5rem;
}

ul.featured-profiles li, ul.mini-profile-grid li {
    margin-left: 0;
}

.dashboard-nav {
    list-style: none;
    margin-left: 0
}

    .dashboard-nav a {
        display: block;
        color: rgba(14, 83, 116, 0.6);
        font-size: 1rem;
        padding: 1rem 1.875rem
    }

        .dashboard-nav a:hover {
            color: #0e5374
        }

    .dashboard-nav .icon-label {
        padding-left: 0.375rem
    }

    .dashboard-nav li {
        border-bottom: 0.0625rem solid rgba(190, 190, 190, 0.45)
    }

        .dashboard-nav li.active a {
            border-left: 0.5rem solid #d56f23;
            padding-left: 1.375rem;
            color: #0e5374
        }

.dashboard .cohort-details .button {
    margin-bottom: 0;
    box-shadow: none
}

.dashboard .cohort-details label {
    font-weight: bold;
    color: white;
    margin-bottom: 0.625rem
}

.dashboard .cohort-details select {
    margin-bottom: 0;
    font-weight: normal;
    font-size: 0.875rem;
    height: auto;
    padding: 0.25rem
}

.stat-blocks {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column
}

.stat-block {
    width: 100%;
    margin-bottom: 1.25rem;
    border: 0.0625rem solid #ddd;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 1.25rem 1rem
}

    .stat-block .icon {
        width: 3.875rem;
        -webkit-flex-shrink: 0;
        -ms-flex-negative: 0;
        flex-shrink: 0;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center
    }

    .stat-block .text {
        width: 100%;
        -webkit-flex-shrink: 1;
        -ms-flex-negative: 1;
        flex-shrink: 1;
        text-align: right;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: center;
        -webkit-justify-content: center;
        -ms-flex-pack: center;
        justify-content: center;
        margin-left: 1rem
    }

        .stat-block .text .number {
            font-weight: bold;
            font-size: 2.25rem;
            display: block;
            line-height: 1
        }

        .stat-block .text .description {
            font-size: 0.875rem;
            font-weight: bold
        }

    .stat-block .subtext {
        display: block;
        font-style: italic;
        font-size: 0.875rem;
        color: #7d8386
    }

.mini-profile-grid {
    list-style: none;
    margin-left: 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.mini-profile-grid li {
width: 12%;
margin-bottom: .5%
}

.mini-profile-grid li.sign-off {
    width: 37%;
    background: #33aab8;
    color: white;
    font-weight: bold;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center
}

.mini-profile-grid li.sign-off.prime {
    background: #d38c1e
}



@media only screen and (min-width: 40.0625em) {
    .featured-profiles {
        display: block;
        padding: 0;
        margin: 0 -0.625rem;
        margin-bottom: 1.3125rem
    }

    .featured-profiles:before,
    .featured-profiles:after {
        content: " ";
        display: table
    }

    .featured-profiles:after {
        clear: both
    }

    .featured-profiles > li {
        display: block;
        float: left;
        height: auto;
        padding: 0 0.625rem 1.25rem
    }

    .featured-profiles > li {
        list-style: none;
        padding: 0 0.625rem 1.25rem;
        width: 25%
    }

    .featured-profiles > li:nth-of-type(1n) {
        clear: none
    }

    .featured-profiles > li:nth-of-type(4n+1) {
        clear: both
    }
}

@media only screen and (min-width: 64.0625em) {
    .featured-profiles {
        display: block;
        padding: 0;
        margin: 0 -0.625rem;
        margin-bottom: 1.3125rem
    }

    .featured-profiles:before,
    .featured-profiles:after {
        content: " ";
        display: table
    }

    .featured-profiles:after {
        clear: both
    }

    .featured-profiles > li {
        display: block;
        float: left;
        height: auto;
        padding: 0 0.625rem 1.25rem
    }

    .featured-profiles > li {
        list-style: none;
        padding: 0 0.625rem 1.25rem;
        width: 20%
    }

    .featured-profiles > li:nth-of-type(1n) {
        clear: none
    }

    .featured-profiles > li:nth-of-type(5n+1) {
        clear: both
    }
}


/* END Dashboard Stuff */

/* PD Plan */
.excerpt-block {
    border: 1px solid #d4d0d0;
    margin-bottom: 1.25rem;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    background: white;
    position: relative;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
    width: 100%;
}

.excerpt-block .heading {
    min-height: 0.3125rem;
    background: #d38c1e;
    font-size: 0.875rem;
    color: white;
    font-weight: 600;
    padding: 0.1875rem 0.6875rem;
    margin-bottom: 0.75rem;
}

.excerpt-block .heading + .content {
    padding-top: 0;
}

.excerpt-block .content {
    padding: 0.75rem 0.75rem 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
}

.excerpt-block .content .content-inner {
    -webkit-flex-shrink: 1;
    -ms-flex-negative: 1;
    flex-shrink: 1;
    display: block;
    width: 100%;
}

/* END PD Plan */



.tiles {
    display: flex;
    flex-wrap: wrap;
    margin: 0 0 27px
}

    .tiles > a {
        width: calc(33.33% - 12px);
        border: 1px solid #cbccd0;
        border-radius: 5px;
        display: flex;
        align-items: center;
        padding: 27px;
        margin: 0 18px 18px 0;
        color: #425072 !important;
        font-family: Geogrotesque Cond W01 Bold,Helvetica Neue,Helvetica,Roboto,Arial,sans-serif;
        font-size: 22px
    }

        .tiles > a span {
            font-size: 18px;
            color: #4a4a4a;
            font-family: Geogrotesque Regular,Helvetica Neue,Helvetica,Roboto,Arial,sans-serif;
            display: block;
            padding: 10px 0
        }

        .tiles > a:nth-child(3n) {
            margin-right: 0
        }

        .tiles > a:hover {
            text-decoration: none;
            background: #f5f5f5
        }

        .tiles > a > div:first-child {
            padding: 0 18px 0 0
        }

            .tiles > a > div:first-child img {
                max-width: 60px;
                height: auto
            }

@media only screen and (max-width: 900px) {
    .tiles > a {
        width: calc(50% - 9px)
    }

        .tiles > a:nth-child(3n) {
            margin-right: 18px
        }

        .tiles > a:nth-child(2n) {
            margin-right: 0
        }
}

@media(min-width: 0em) and (max-width:48em) {
    .tiles > a {
        width: 100%;
        margin-right: 0
    }

        .tiles > a:nth-child(3n) {
            margin-right: 0
        }
}


@media (min-width:48em) {
    .answergrid {
        display: grid;
        grid-template-columns: auto auto auto auto auto;
        padding: 8px;
    }
}

.popup {
    z-index: 150;
}

.section-level-up {
    z-index: 1;
}

/* BEGIN: MARTIN STUFF ML: 04-09-2020 */

div.performance {
    cursor: pointer;
}

.performances-details > div > div.performance-details-connections {
    margin-top: 0px;
}

.standards-table td p a.extended-width {
    width: calc(100% - 60px);
}

a.standards-title {
    color: #4a4a4a;
}

a.standards-title-green {
    color: #3e7b25;
}

a.standards-title-white {
    color: #f5f5f5;
    text-decoration: none;
}

    a.standards-title-white:hover {
        color: #f5f5f5;
        text-decoration: underline;
    }

.ngss-practices {
    background: #5167bf;
}

.ngss-dcis {
    background: #fe991f;
}

.ngss-cc {
    background: #3e7b25;
}

h5.white {
    color: #fff;
}

.button.outline-ngss-practice,
input[type=button].outline-ngss-practice {
    border: 1px solid #fff;
    background: none;
    border-radius: 5px;
    color: #fff;
}

    .button.outline-ngss-practice:hover,
    input[type=button].outline-ngss-practice:hover {
        background: #fff;
        border: 1px solid #fff;
        color: #868789 !important;
    }

.ngss-sub-container {
    padding-top: 10px !important;
    padding-bottom: 0px !important;
    cursor: default !important;
}

h4.ngss-other-practices {
    margin-bottom: 10px;
}

.page-wrap ul.ngss-list li:before {
    content: '\f111';
}

.performances-details > div p.info a.resources-subsection {
    font-size: 14px;
    color: #4A4A4A;
    text-decoration: none;
}

    .performances-details > div p.info a.resources-subsection:hover {
        color: #4A4A4A;
        text-decoration: underline;
    }

.validatorStyle {
    color: Red;
}

    .validatorStyle ul li {
        color: Red;
        list-style-type: circle;
    }

/* END: MARTIN STUFF */

/* 
ML 06-11-2020 Think about handling a printed page since menu is covering stuff (esp receipts) where you get a big orange bar
*/

@media print {
    .mobile-nav, footer, .global-mobile-nav, .site-header, .social {
        display: none !important;
    }
}



.event-session {
    display: flex;
    flex-wrap: wrap-reverse;
    margin-bottom: 1.5rem;
    width: 100% !important;
}

    .event-session .time {
        width: 200px;
        padding-top: 0.5rem;
        flex-grow: 1;
        text-align: center;
    }

        .event-session .time h5 {
            font-weight: bold;
            font-size: 20px;
            border-bottom: 1px solid #000;
            margin: 0 1.5rem;
            text-align: center;
        }

        .event-session .time .agenda-add {
            margin-top: 1rem;
            color: #777;
        }

    .event-session .details {
        width: 350px;
        flex-grow: 20;
        border: 1px solid #aaa;
        border-radius: 5px;
        padding: 1rem;
    }

        .event-session .details h4 {
            margin: 0.5rem 0;
            color: #425072;
        }

.exhibit-product {
    display: flex;
    flex-wrap: wrap-reverse;
    margin-bottom: 1.5rem;
    width: 100% !important;
}

    .exhibit-product .product {
        width: 250px;
        /*padding-top: 0.5rem;*/
        flex-grow: 1;
        text-align: center;
    }

        .exhibit-product .product .image {
            border-radius: 5px;
        }

    .exhibit-product .details {
        width: 300px;
        flex-grow: 20;
        border: 1px solid #aaa;
        border-radius: 5px;
        padding: 1rem;
    }

        .exhibit-product .details h4 {
            margin: 0.5rem 0;
            color: #425072;
        }

@font-face {
    font-family: "Geogrotesque-Light";
    src: url("/fonts/Geogrotesque Cond W03 Light.eot"); /* IE9*/
    src: url("/fonts/Geogrotesque Cond W03 Light.eot?#iefix") format("embedded-opentype"), /* IE6-IE8 */
    url("/fonts/Geogrotesque Cond W03 Light.woff2") format("woff2"), /* chrome、firefox */
    url("/fonts/Geogrotesque Cond W03 Light.woff") format("woff"), /* chrome、firefox */
    url("/fonts/Geogrotesque Cond W03 Light.ttf") format("truetype"), /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/
    url("/fonts/Geogrotesque Cond W03 Light.svg#Geogrotesque Light") format("svg"); /* iOS 4.1- */
}

@font-face {
    font-family: "Geogrotesque";
    src: url("/fonts/Geogrotesque-Regular.eot"); /* IE9*/
    src: url("/fonts/Geogrotesque-Regular.eot?#iefix") format("embedded-opentype"), /* IE6-IE8 */
    url("/fonts/Geogrotesque-Regular.woff2") format("woff2"), /* chrome、firefox */
    url("/fonts/Geogrotesque-Regular.woff") format("woff"), /* chrome、firefox */
    url("/fonts/Geogrotesque-Regular.ttf") format("truetype"), /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/
    url("/fonts/Geogrotesque-Regular.svg#Geogrotesque Light") format("svg"); /* iOS 4.1- */
}

.error-container {
    color: red;
}

    .error-container ul li {
        color: red;
    }

.skeleton {
    animation: skeleton-loading 1s linear infinite alternate;
}

@keyframes skeleton-loading {
    0% {
        background-color: hsl(200, 20%, 80%);
    }

    100% {
        background-color: hsl(200, 20%, 95%);
    }
}

.skeleton-text {
    width: 100%;
    height: 1rem;
    margin-bottom: 0.5rem;
    border-radius: 0.25rem;
}

.skeleton-text__body {
    width: 75%;
}

.skeleton-footer {
    width: 30%;
}

input[type="file"] {
    display: none;
}

.custom-file-upload {
    border: 1px solid #ccc;
    display: inline-block;
    padding: 6px 12px;
    cursor: pointer;
    border-radius: 3px;
}


@media (min-width: 48em) {
    .columned {
        column-count: 4;
    }
}

.proposals {
    background-color: white;
    z-index: 1;
    position: relative;
}

.proposal-title {
    max-width: 800px;
}

.proposal-actions {
    display: flex;
    width: 232px;
    margin: 1rem 0;
    padding-left: 2rem;
    border-left: 1px solid #dce4f0;
}

.material-title {
    min-width: 550px;
    max-width: 550px;
    overflow-wrap: break-word;
    padding-right: 1.5rem;
}

@media (min-width: 0em) and (max-width: 48em) {
    .mobile-wrap {
        flex-wrap: wrap;
    }

    .proposal-title {
        max-width: 288px;
    }

    .proposal-status {
        margin-bottom: 1rem;
    }

    .proposal-actions {
        border-left: 0;
    }

    .material-title {
        min-width: 250px;
        max-width: 250px;
    }

    .material-delete {
        width: 100%;
        text-align: right;
    }
}

@media print {
    .proposals div:nth-child(3n) {
        page-break-after: always;
    }
}


.tooltip {
    position: relative;
    display: inline-block
}

    .tooltip .tooltiptext {
        visibility: hidden;
        width: 120px;
        background-color: #555;
        color: #fff !important;
        text-align: center;
        padding: 5px 0;
        border-radius: 6px;
        position: absolute;
        z-index: 1;
        opacity: 0;
        transition: opacity .6s
    }

    .tooltip:hover .tooltiptext {
        visibility: visible;
        opacity: 1
    }

.tooltip-top {
    bottom: 125%;
    left: 50%;
    margin-left: -60px;
}

    .tooltip-top::after {
        content: "";
        position: absolute;
        top: 100%;
        left: 50%;
        margin-left: -5px;
        border-width: 5px;
        border-style: solid;
        border-color: #555 transparent transparent transparent;
    }

.tooltip-top-right {
    bottom: 125%;
    left: 50%;
    margin-left: -20px;
}

    .tooltip-top-right::after {
        content: "";
        position: absolute;
        top: 100%;
        left: 5%;
        margin-left: -5px;
        border-width: 5px;
        border-style: solid;
        border-color: #555 transparent transparent transparent;
    }

.tooltip-top-left {
    bottom: 125%;
    right: 50%;
    margin-left: -20px;
}

    .tooltip-top-left::after {
        content: "";
        position: absolute;
        top: 100%;
        right: 5%;
        margin-left: -5px;
        border-width: 5px;
        border-style: solid;
        border-color: #555 transparent transparent transparent;
    }


.icon-action {
    color: #000;
    opacity: .30;
}

.button.small.short {
    margin: 0;
    padding: 2px 12px;
    border-radius: 2px;
    color: #fff;
    opacity: 0.8;
    font-size: 16px;
}

.button-action {
    position: absolute;
    right: 0;
    top: 16px;
    padding: 0 10px;
    background-color: #fff;
    width: 250px;
    justify-content: space-between;
}

input.underline {
    height: 36px !important;
    border: 0 !important;
    border-bottom: 1px solid #cbccd0 !important;
    border-radius: 0 !important;
}


.c-ticket {
    padding: 1rem;
    width: 100%;
}

    .c-ticket .c-ticket-content {
        position: relative;
        outline: 2px solid transparent;
        border: 1px solid #dae2ef;
        border-top: 15px solid #dae2ef;
        border-radius: 5px;
        /*height: 250px;*/
        transform: translate3d(0,0,0);
        transition-property: box-shadow,transform;
        transition-duration: 400ms;
        transition-timing-function: cubic-bezier(.16,1,.29,.99);
        flex-grow: 1;
        overflow: hidden;
        box-shadow: 0 2px 8px rgba(0,0,0,.05);
        /*background-color: #f2f2f2;*/
    }

        .c-ticket .c-ticket-content.tall {
            height: 320px !important;
        }

.c-ticket-content:hover, .c-ticket-content:focus {
    transform: translate3d(0,-4px,0);
    box-shadow: 0 12px 30px 0 rgba(0,0,0,.2);
    transition-property: box-shadow,transform;
    transition-duration: 600ms;
    transition-timing-function: cubic-bezier(.16,1,.29,.99)
}

.ng-scope {
    margin: 24px;
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.c-ticket-price-member {
    font-weight: 600;
    margin-bottom: 4px;
}

.c-ticket-price-nonmember {
    font-size: 16px;
    line-height: 1.5;
}

.c-ticket-text {
    width: 340px;
}

.c-ticket-title-price {
    display: flex;
    justify-content: space-between
}

.c-ticket-button {
    /*margin: 68px 16px 0 auto;*/
    text-align: right;
    max-width: 120px;
}

    .c-ticket-button .button {
        padding: 8px 12px !important;
        width: 106px;
    }

.c-ticket-note {
    font-size: 16px;
    opacity: .7;
    margin: 24px;
}

@media (min-width: 0em) and (max-width: 48em) {
    .ng-scope {
        height: unset;
    }

    .c-ticket .c-ticket-content {
        height: 450px;
    }

        .c-ticket .c-ticket-content.tall {
            height: 585px !important;
        }

        .c-ticket .c-ticket-content .mobile-hide {
            display: none;
        }

    .c-ticket-text {
        width: 100%;
    }

    .c-ticket-button {
        margin: 0;
    }
}






.fade {
    transition: opacity .15s linear;
}

.modal {
    --bs-modal-zindex: 1055;
    --bs-modal-width: 400px;
    --bs-modal-padding: 1rem;
    --bs-modal-margin: 0.5rem;
    --bs-modal-color:;
    --bs-modal-bg: #fff;
    --bs-modal-border-color: var(--bs-border-color-translucent);
    --bs-modal-border-width: 1px;
    --bs-modal-border-radius: 0.5rem;
    --bs-modal-box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --bs-modal-inner-border-radius: calc(0.5rem - 1px);
    --bs-modal-header-padding-x: 1rem;
    --bs-modal-header-padding-y: 1rem;
    --bs-modal-header-padding: 1rem 1rem;
    --bs-modal-header-border-color: var(--bs-border-color);
    --bs-modal-header-border-width: 1px;
    --bs-modal-title-line-height: 1.5;
    --bs-modal-footer-gap: 0.5rem;
    --bs-modal-footer-bg:;
    --bs-modal-footer-border-color: var(--bs-border-color);
    --bs-modal-footer-border-width: 1px;
    position: fixed;
    top: 0;
    left: 0;
    z-index: var(--bs-modal-zindex);
    display: none;
    width: 100%;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    outline: 0;
    max-width: 100%;
    max-height: 100%;
}

.modal {
    --bs-modal-margin: 1.75rem;
    --bs-modal-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

    .modal.show .modal-dialog {
        transform: none;
    }

    .modal.fade .modal-dialog {
        transition: transform .3s ease-out;
        transform: translate(0,-50px);
    }

@media (min-width: 576px) {
    .modal-dialog {
        max-width: var(--bs-modal-width);
        margin-right: auto;
        margin-left: auto;
    }
}

.modal-dialog-centered {
    display: flex;
    align-items: center;
    min-height: calc(100% - var(--bs-modal-margin) * 2);
}

.modal-dialog-scrollable {
    height: calc(100% - var(--bs-modal-margin) * 2);
}

.modal-dialog {
    position: relative;
    width: auto;
    margin: var(--bs-modal-margin);
    pointer-events: none;
}

@media (min-width: 576px) {
    .modal-dialog {
        max-width: var(--bs-modal-width);
        margin-right: auto;
        margin-left: auto;
    }
}

@media (min-width: 576px) {

    .modal-sm {
        --bs-modal-width: 300px;
    }
}


.modal-scrollbar-measure {
    position: absolute;
    top: -9999px;
    width: 50px;
    height: 50px;
    overflow: scroll;
}

@media (min-width: 576px) {
    .modal-dialog {
        max-width: 500px;
        margin: 1.75rem auto;
    }

    .modal-dialog-scrollable {
        max-height: calc(100% - 3.5rem);
    }

        .modal-dialog-scrollable .modal-body {
            overflow-y: auto;
        }

        .modal-dialog-scrollable .modal-content {
            max-height: calc(100vh - 3.5rem);
        }

    .modal-dialog-centered {
        min-height: calc(100% - 3.5rem);
    }

        .modal-dialog-centered::before {
            height: calc(100vh - 3.5rem);
        }

    .modal-sm {
        max-width: 300px;
    }
}

@media (min-width: 992px) {
    .modal-lg,
    .modal-xl {
        max-width: 800px;
    }
}

@media (min-width: 1200px) {
    .modal-xl {
        max-width: 1140px;
    }
}

.modal-dialog-scrollable .modal-content {
    max-height: 100%;
    overflow: hidden;
}

.modal-content {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    color: var(--bs-modal-color);
    pointer-events: auto;
    background-color: var(--bs-modal-bg);
    background-clip: padding-box;
    border: var(--bs-modal-border-width) solid var(--bs-modal-border-color);
    border-radius: var(--bs-modal-border-radius);
    outline: 0;
}

.modal-header {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: space-between;
    padding: var(--bs-modal-header-padding);
    padding-bottom: 0;
    border-bottom: var(--bs-modal-header-border-width) solid var(--bs-modal-header-border-color);
    border-top-left-radius: var(--bs-modal-inner-border-radius);
    border-top-right-radius: var(--bs-modal-inner-border-radius);
}

.modal-body {
    position: relative;
    flex: 1 1 auto;
    padding: var(--bs-modal-padding);
}

.modal-footer {
    display: flex;
    flex-shrink: 0;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    padding: calc(var(--bs-modal-padding) - var(--bs-modal-footer-gap) * .5);
    background-color: var(--bs-modal-footer-bg);
    border-top: var(--bs-modal-footer-border-width) solid var(--bs-modal-footer-border-color);
    border-bottom-right-radius: var(--bs-modal-inner-border-radius);
    border-bottom-left-radius: var(--bs-modal-inner-border-radius);
}

.modal-backdrop {
    --bs-backdrop-zindex: 1050;
    --bs-backdrop-bg: #000;
    --bs-backdrop-opacity: 0.5;
    position: fixed;
    top: 0;
    left: 0;
    z-index: var(--bs-backdrop-zindex);
    width: 100vw;
    height: 100vh;
    background-color: var(--bs-backdrop-bg);
}

    .modal-backdrop.fade {
        opacity: 0;
    }

    .modal-backdrop.show {
        opacity: var(--bs-backdrop-opacity);
    }

.modal.show .modal-dialog {
    transform: none;
}





.also-items > a:nth-child(4n) {
    margin-right: 0
}

.also-item {
    width: calc(25% - 16px);
    border: 0; /*1px solid #cbccd0;*/
    border-radius: 8px;
    -webkit-box-shadow: 0px 3px 6px 0px #DAE2EF;
    box-shadow: 0px 3px 6px 0px #DAE2EF;
    text-decoration: none;
    display: block;
    padding: 0;
    margin: 0 20px 14px 0;
    color: #283359 !important;
    background-color: #fff;
    font-size: 14px
}

    .also-item:hover {
        text-decoration: none;
    }

.also-item-image {
    width: 100%;
    height: 150px;
    border-radius: 8px 8px 0 0;
    background-color: #283359;
    background-position: 0 5%;
    background-size: 100% auto;
}

.also-item-info {
    height: 130px;
    margin: 16px;
    font-weight: 200;
}

    .also-item-info .type {
        color: #aaa;
    }

    .also-item-info .title {
        font-size: 18px;
        font-weight: 600;
        padding: 10px 0;
    }

.also-item-price {
    display: flex;
    align-items: center;
    font-size: 18px;
    margin: 0 16px;
    padding: 10px 0;
    border-top: 1px solid #d9e2ef;
}

    .also-item-price > div > div {
        padding-top: 8px;
    }





.article-row {
    display: flex;
    align-items: center;
}

.article-lock {
    min-width: 50px;
    color: #dae2ef;
}

.article-type {
    font-size: 14px;
    color: #aaa;
}

.article-title {
    padding: 12px 0;
    font-size: 22px;
    font-weight: 600;
    color: #283359;
}

.article-authors {
    font-size: 14px;
    color: #283359;
}

.article-action {
    margin-left: auto;
    font-size: 18px;
    color: #0091CA;
}

    .article-action > a:hover {
        text-decoration: none;
    }


.article-abstract {
    font-family: "Rubik-Light";
    display: none;
    margin-left: 50px;
    margin-right: 150px;
    margin-bottom: 1.5rem;
    margin-top: 1.5rem;
    line-height: 1.5;
}

.article-carat {
    margin-left: 90px;
    font-size: 18px;
    color: #0091CA;
    width: 28px;
}

    .article-carat i {
        font-size: 28px;
    }

@media(min-width: 0em) and (max-width:48em) {

    .blurb {
        margin-left: 1rem;
    }

    .article-title {
        min-width: 220px;
    }

    .article-carat {
        margin-left: 30px;
    }

    .article-action {
        margin-left: 0;
        padding: 1rem 0;
    }

    .article-abstract {
        margin-right: 0;
    }

    .also-item {
        min-width: 269px;
        margin: 1rem auto;
    }

    .also-items > a:nth-child(4n) {
        margin-right: auto;
    }
}



.button-purple {
    display: inline-block;
    text-align: center;
    line-height: 50px;
    background-color: #5c3bfe;
    color: #fff;
    border-radius: 25px;
    border: 1px solid #fff;
    width: 180px;
    height: 50px;
    font-size: 20px;
}

    .button-purple:hover {
        background-color: #fff;
        color: #5c3bfe;
        text-decoration: none;
    }

    .button-purple:active {
        background-color: #f0f3f9;
    }

.button-white {
    display: inline-block;
    text-align: center;
    line-height: 50px;
    background-color: #f0f3f9;
    color: #5c3bfe;
    border-radius: 25px;
    border: 1px solid #5c3bfe;
    width: 180px;
    height: 50px;
    font-size: 20px;
}

    .button-white:hover {
        background-color: #fff;
        color: #5c3bfe;
        text-decoration: none;
    }

    .button-white:active {
        background-color: #eaeaea;
    }




.search-results-grid-parent {
    display: flex;
    flex-wrap: wrap;
}

    .search-results-grid-parent > div {
        flex-shrink: 0;
    }

@media (min-width: 48em) {
    .search-results-grid-parent > div:nth-child(3n) {
        margin-right: 0;
    }
}


.search-result-grid {
    position: relative;
    min-height: 200px;
    width: calc(33% - 12px);
    text-align: left;
    border-radius: 5px;
    border: 1px solid #e0e0e0;
    padding: 0;
    margin: 20px 20px 0 0;
    box-shadow: 0px 2px 5px 2px rgba(0,0,0,0.10);
    -webkit-box-shadow: 0px 2px 5px 2px rgba(0,0,0,0.10);
}

.search-result-grid-details {
    padding: 5px 18px 18px 18px;
    position: relative;
    z-index: 3;
}

    .search-result-grid-details > .top {
        position: relative;
        min-height: 310px;
    }

.search-result-grid-title {
    font-size: 18px !important;
    font-weight: 600;
    text-decoration: none;
    line-height: 24px;
    color: #0091CA;
    padding-top: 12px;
}

.search-result-grid-author {
    font-size: 14px !important;
    font-weight: 600;
    text-decoration: none;
    line-height: 20px;
    color: #283359;
    margin-top: 12px;
}

.search-result-grid-image {
    display: flex;
    justify-content: space-between;
    padding: 8px;
    background-color: #283359;
    background-repeat: no-repeat;
    background-position: 50% 16px;
    background-size: 160px;
    height: 120px;
    border-radius: 5px 5px 0 0;
}

.search-result-grid-image-hover {
    opacity: 0;
    transition: opacity .55s ease-in-out;
    position: absolute;
    top: 16px;
    left: 58px;
    width: 160px;
    z-index: 2;
    box-shadow: 0 5px 5px 0 rgba(0, 0, 0, 0.15);
}

    .search-result-grid-image-hover:hover {
        opacity: 1.0;
        transition: opacity .55s ease-in-out;
        z-index: 4;
    }


.search-result-grid-wishlist {
    background: #fff;
    border-radius: 15px;
    padding: 2px 5px;
}

.search-result {
    position: relative;
    min-height: 150px;
    max-width: 785px;
    text-align: left;
    border-radius: 5px;
    border: 1px solid #e0e0e0;
    padding: 0;
    margin: 20px 0;
    box-shadow: 0px 2px 5px 2px rgba(0,0,0,0.10);
    -webkit-box-shadow: 0px 2px 5px 2px rgba(0,0,0,0.10);
}

.search-result-details {
    padding: 5px 20px 20px 20px;
    display: flex;
}

.result-details {
    width: 100%;
    border-bottom: 1px solid #e0e0e0;
}

.result-title {
    font-family: "Geogrotesque";
    font-size: 20px !important;
    font-weight: 600;
    text-decoration: none;
    line-height: 26px;
    color: #0091CA;
}

.result-author {
    font-size: 16px !important;
    font-weight: 800;
    text-decoration: none;
    color: #283359;
    margin: 1rem 0;
}

.result-prices {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 1rem 0;
}

.result-price {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 1rem;
}

.result-price-label {
    font-size: 14px;
    font-weight: 400;
    height: 22px;
}

.result-image {
    max-width: 200px;
    border: none;
    padding: 0 20px 0 0;
}

.result-image-mobile {
    display: none;
}

.result-abstract {
    font-size: 16px;
    font-family: "Rubik-Light" !important;
    line-height: 24px;
}

.result-formats {
    font-size: 16px;
    margin-bottom: 10px;
    color: #283359;
}

.modal-item-details {
    font-size: 16px;
}

.modal-item-title {
    font-family: "Geogrotesque";
    font-size: 18px;
    font-weight: 800;
    color: #283359;
    margin: 1rem 0;
}

.modal-item-authors {
    font-size: 16px;
    font-weight: 600;
    color: #b0b8c7;
    padding-bottom: 12px;
    border-bottom: 3px solid #dee3ee;
}


.highlighted-column {
    background: none;
    border-radius: 5px;
    padding: 0;
    margin: 0 1rem 0 0;
    max-width: 300px;
}

    .highlighted-column .fieldgroup {
        border-bottom: 1px solid #283359;
        padding: 0 0 1rem 10px;
    }

    .highlighted-column .fieldset-wrapper {
        padding: 0 0 0 1rem;
    }

    .highlighted-column legend {
        color: #283359;
        font-size: 18px;
        font-family: "Geogrotesque";
        font-weight: 800;
        margin: 0 0 9px 0;
    }

    .highlighted-column [type="checkbox"] + label {
        color: #283359 !important;
        display: inline-block !important;
        font-size: 16px !important;
        font-family: 'Geogrotesque' !important;
        margin: 0 !important;
        line-height: 1.4;
        text-transform: none;
    }

    .highlighted-column [type="checkbox"]:checked + label {
        font-family: 'Geogrotesque' !important;
        font-weight: bold;
    }

        .highlighted-column [type="checkbox"]:not(:checked) + label:before, .highlighted-column [type="checkbox"]:checked + label:before {
            top: 3px !important;
            background: #fff;
            width: 16px;
            height: 16px;
        }

        .highlighted-column [type="checkbox"]:checked + label:before {
            border: 1px solid #283359;
            background: #283359;
            color: #fff;
            box-shadow: none;
        }

[type="checkbox"]:not(:checked) + label:before, [type="checkbox"]:checked + label:before {
    content: '';
    position: absolute;
    left: 6px;
    top: 2px;
    width: 17px;
    height: 17px;
    border-radius: 3px;
    border: 1px solid #283359;
}

.highlighted-column [type="checkbox"]:not(:checked) + label:after, .highlighted-column [type="checkbox"]:checked + label:after {
    top: 5px !important;
    left: 8px;
    color: #fff;
    text-shadow: none;
    font-size: 14px;
}

.filter-toggle {
    display: none !important;
}

.membership-sign-in-up {
    min-width: 684px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    color: #fff;
    justify-content: center;
    background-color: #5c3bfe;
    padding: 15px;
}

    .membership-sign-in-up > .message {
        padding: 8px;
        font-weight: 600;
        margin-right: 3rem;
    }

.search-box-mobile {
    border-radius: 5px 0 0 5px !important;
    height: 44px !important;
    background: #fff;
    border-color: #ccc;
}

@media (max-width: 48em) and (min-width: 0em) {

    .member-toggle {
        display: none;
    }

    .section-level-up {
        padding-top: 30px;
    }

    .filter-toggle {
        display: block !important;
    }

        .filter-toggle.inline {
            display: inline-block !important;
            margin-bottom: 30px;
            /*width: unset !important;*/
        }

    .filter-hidden {
        display: inline !important;
    }

    #btnFilterMobile {
        display: inline-block !important;
    }

    #divFilterMobile, #divAdditionalInfo {
        display: none;
    }

    .highlighted-column {
        display: none;
        margin-right: 0;
    }

    .toggle-wrapper {
        margin-right: 0 !important;
    }

    .search-membership-bar {
        flex-direction: column-reverse;
    }

    .membership-sign-in-up {
        min-width: 100%;
        justify-content: space-between;
    }

        .membership-sign-in-up > .message {
            max-width: 175px;
            margin-right: 0;
        }


    .result-thumbnail {
        display: none;
    }

    .result-image {
        max-width: 125px;
    }

    .result-image-mobile {
        display: inline-block;
    }

    .result-title {
        font-size: 16px !important;
    }

    .search-box-mobile {
        width: 86% !important;
    }

    .search-box-mobile-button {
        position: absolute !important;
    }

    .search-results-grid-parent > div:nth-child(2n) {
        margin-right: 0;
    }

    .search-result-grid {
        width: calc(50% - 10px);
        position: static;
    }

    .search-result-grid-image {
        background-size: 130px;
    }

    .search-result-grid-details {
        padding: 5px 10px 10px 10px;
    }

        .search-result-grid-details > .top {
            min-height: 470px;
        }

    .button-increment {
        display: none;
    }
}


.gsc-resultsbox-visible .gsc-resultsRoot .gsc-webResult .gsc-result .gsc-table-result {
    display: flex;
    flex-wrap: wrap;
}

    .gsc-resultsbox-visible .gsc-resultsRoot .gsc-webResult .gsc-result .gsc-table-result .gsc-table-cell-snippet-close {
        width: 100% !important;
    }

.gsc-input-box {
    padding: 0 !important;
    position: absolute;
    top: 0;
    width: calc(100% - 37px);
}

table.gsc-search-box {
    position: relative;
}

#ctl00_contentMain_divSearchBox {
    width: 90% !important;
    margin: auto !important;
}

.hero .blurb .button.right-align {
    height: 45px !important;
    padding: 12px 20px;
}

@media (min-width: 48em) {
    .gsc-resultsbox-visible .gsc-resultsRoot .gsc-webResult .gsc-result .gsc-table-result .gsc-table-cell-thumbnail {
        min-width: 180px;
        float: right;
        width: 20%;
        position: absolute;
        top: 0;
        right: 0;
    }
}


.browse-categories > div > a {
    border: 1px solid #e0e0e0;
    border-radius: 10px;
    padding: 12px 14px;
    display: block;
    margin-right: 10px;
}

    .browse-categories > div > a:hover {
        text-decoration: none;
        background-color: #0091CA;
        color: #fff;
    }

    .browse-categories > div > a > i {
        width: 30px;
    }



.c-card {
    margin: 1rem;
    width: 100%;
}

    .c-card .c-card-content {
        position: relative;
        outline: 2px solid transparent;
        border: 1px solid #dae2ef;
        border-top: 15px solid #dae2ef;
        border-radius: 5px;
        height: 250px;
        transform: translate3d(0,0,0);
        transition-property: box-shadow,transform;
        transition-duration: 400ms;
        transition-timing-function: cubic-bezier(.16,1,.29,.99);
        flex-grow: 1;
        overflow: hidden;
        box-shadow: 0 2px 8px rgba(0,0,0,.05);
        /*background-color: #f2f2f2;*/
    }

        .c-card .c-card-content.tall {
            height: 320px !important;
        }

.c-card-content:hover, .c-card-content:focus {
    transform: translate3d(0,-4px,0);
    box-shadow: 0 12px 30px 0 rgba(0,0,0,.2);
    transition-property: box-shadow,transform;
    transition-duration: 600ms;
    transition-timing-function: cubic-bezier(.16,1,.29,.99)
}

.ng-scope {
    margin: 1rem;
    height: 100%;
    display: flex;
    flex-wrap: wrap;
}

.c-card-text {
    width: 80%;
}

.c-card-button {
    margin: 68px 16px 0 auto;
}

@media (min-width: 0em) and (max-width: 48em) {

    .hero .blurb .button.right-align {
        margin-top: 0 !important;
    }

    .ng-scope {
        height: unset;
    }

    .c-card .c-card-content {
        height: 450px;
    }

        .c-card .c-card-content.tall {
            height: 585px !important;
        }

        .c-card .c-card-content .mobile-hide {
            display: none;
        }

    .c-card-text {
        width: 100%;
    }

    .c-card-button {
        margin: 0;
    }
}


.filter-applied {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: #f0f0f0;
    border: 1px solid #ccc;
    border-radius: 5px;
    padding: 8px;
    margin: 4px;
}
    .filter-applied.off {
        background-color: white;
    }

    .filter-applied span {
        font-size: 16px;
    }

    .filter-applied a {
        color: #283359;
        margin-left: 6px;
    }

        .filter-applied a i {
            font-size: 12px;
        }



.invalid {
    border-color: red !important;
    outline-color: red !important;
}

.validation-message {
    color: red;
    font-size: 14px;
    margin-top: 4px;
    display: block;
}



.session-v3-button {
    width: 215px;
    background: #ffffff;
    border: 1px solid #0075A3;
    color: #0075A3 !important;
    cursor: pointer;
}

    .session-v3-button:hover, .session-v3-button-selected {
        background: #0075A3;
        border: 1px solid #0075A3;
        color: #ffffff !important;
    }

.button.small.session-v3-button-text-filter,
input[type="button"].small.session-v3-button-text-filter {
    font-size: 22px;
}

.session-v3-button-text-small {
    font-size: 16px;
}

.content-with-callouts > div.session-v3-content {
    width: 100%;
    padding: 0 0 27px 0;
}

.session-v3-event-session {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 1.5rem;
    width: 100% !important;
}

    .session-v3-event-session .time {
        width: 100%;
        /*padding-top: 0.5rem;
    flex-grow: 1;
    text-align: center;*/
    }

        .session-v3-event-session .time h5 {
            font-weight: bold;
            font-size: 18px;
            margin: 0;
            /*margin: 0 1.5rem;
    border-bottom: 1px solid #000;
    text-align: center;*/
        }

    .session-v3-event-session .agenda-add {
        display: flex;
        margin-top: 6px;
        color: #5c3bfc;
        align-items: center;
        text-align: right;
    }

    .session-v3-event-session .details {
        width: 350px;
        flex-grow: 20;
        border: 1px solid #aaa;
        border-radius: 5px;
        padding: 1rem;
        position: relative;
    }

        .session-v3-event-session .details h4 {
            margin-top: 12px;
            margin-bottom: 8px;
            margin-left: 0px;
            margin-right: 0px;
            color: #425072;
        }

.session-v3-agenda {
    /*position: absolute;
    top: 0;
    right: 0;
    padding-right: 5px;*/
}

a.session-v3-link {
    font-weight: bold;
    text-decoration: underline;
    cursor: pointer;
}

a:hover.session-v3-link {
    text-decoration: none;
    cursor: pointer;
}

.session-v3-link-agenda-item {
    color: #5c3bfc;
    font-weight: bold;
    border: 0;
    background-color: #fff;
    font-size: 16px;
}

    .session-v3-link-agenda-item:hover {
        cursor: pointer;
    }

a.session-v3-filter-link {
    font-weight: bold;
    text-decoration: none;
    cursor: pointer;
    font-size: 22px;
    color: white;
}

a:hover.session-v3-filter-link {
    text-decoration: underline;
    cursor: pointer;
}

.session-v3-visible {
    visibility: visible;
}

.session-v3-hidden {
    visibility: hidden;
    display: none;
}

.session-v3-results-filter-col1 {
    display: inline-block;
    width: 90%;
}

.session-v3-results-filter-col2 {
    display: inline-block;
    width: 10%;
    text-align: right;
    align-self: center;
}

.session-v3-search-col1 {
    width: 500px;
}

.session-v3-search-col2 {
    width: 500px;
    text-align: center;
    align-self: center;
    display: flex;
}

.button.session-v3-search,
input[type="button"].session-v3-search {
    border-radius: 0 5px 5px 0;
    padding-top: 9px;
    padding-right: 15px;
    padding-bottom: 12px;
    padding-left: 15px;
    font-size: 21px;
    line-height: 1.1em;
    font-family: Ionicons !important;
    /*float: left;*/
    width: auto;
    min-width: 1px;
    margin-top: 0px;
    position: relative;
    z-index: 10;
    margin-left: -4px;
}

.session-v3-checkboxes td [type="radio"]:not(:checked) + label:before,
.session-v3-checkboxes td [type="radio"]:checked + label:before {
    border-color: white;
    top: 8px;
    width: 14px;
    height: 14px;
}

.session-v3-checkboxes td [type="radio"] + label {
    color: white;
    font-size: 22px;
}

.session-v3-checkboxes td [type="radio"]:checked + label:before {
    box-shadow: none;
}

.session-v3-checkboxes td [type="checkbox"]:not(:checked) + label:before,
.session-v3-checkboxes td [type="checkbox"]:checked + label:before {
    border-color: white;
    top: 5px;
}

.session-v3-checkboxes td [type=checkbox]:not(:checked) + label:after,
.session-v3-checkboxes td [type=checkbox]:checked + label:after {
    top: 4px;
}

.session-v3-checkboxes td [type="checkbox"] + label {
    color: white;
    font-size: 22px;
}

.session-v3-checkboxes td [type="checkbox"]:checked + label {
    font-weight: bold;
}

.session-v3-filter-flex {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 20px;
}

    .session-v3-filter-flex .session-v3-filter-grade {
        color: white;
        font-size: 22px;
        /*width: 200px;*/
        width: 26%;
        order: 1;
    }

    .session-v3-filter-flex .session-v3-filter-other {
        /*border: 1px solid white;*/
        color: white;
        font-size: 22px;
        /*flex-grow: 2;*/
        width: 48%;
        order: 2;
    }

    .session-v3-filter-flex .session-v3-filter-apply {
        color: white;
        font-size: 22px;
        /*width: 200px;*/
        width: 26%;
        order: 3;
    }

.session-v3-content-details-display p,
.session-v3-content-details-display li {
    font-family: "Rubik-Light","Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;
    font-size: 16px;
}


/* CSS-only Progress Bar */
.progress-container {
    width: 100%;
    height: 8px;
    background-color: #eee;
    border-radius: 4px;
    overflow: hidden;
    position: relative;
    margin: 12px 0;
}

.progress-bar {
    height: 100%;
    background: linear-gradient(90deg, #0075A3, #00A3D9);
    border-radius: 4px;
    transition: width 0.3s ease;
    position: relative;
}

    .progress-bar.animated {
        background: linear-gradient(90deg, #0075A3, #00A3D9, #0075A3);
        background-size: 200% 100%;
        animation: progressAnimation 2s linear infinite;
    }

@keyframes progressAnimation {
    0% {
        background-position: 200% 0;
    }

    100% {
        background-position: -200% 0;
    }
}

/* Variants */
.progress-container.small {
    height: 4px;
    max-width: 150px;
}

.progress-container.large {
    height: 12px;
}

.progress-container.rounded {
    border-radius: 10px;
}

    .progress-container.rounded .progress-bar {
        border-radius: 10px;
    }

/* Color variants */
.progress-bar.success {
    background: linear-gradient(90deg, #00C38E, #4CAF50);
}

.progress-bar.warning {
    background: linear-gradient(90deg, #FFA500, #FF9800);
}

.progress-bar.danger {
    background: linear-gradient(90deg, #DD0000, #F44336);
}

/* With percentage text */
.progress-container.with-text {
    height: 24px;
    background-color: #f5f5f5;
    border: 1px solid #ddd;
}

    .progress-container.with-text .progress-bar {
        display: flex;
        align-items: center;
        justify-content: center;
        color: white;
        font-size: 12px;
        font-weight: 600;
        text-shadow: 0 1px 2px rgba(0,0,0,0.3);
    }



@media (min-width: 0em) and (max-width:31.25rem) {
    /*.sessions-v3-days-header-append > div:first-child {
        width: 100%;
    }

    .sessions-v3-days-header-append > div:not(:first-child) {
        width: 22%;
    }

    .session-v3-button {
        width: 100%;
    }

    .sessions-v3-days-header-append {
        justify-content: center;
    }*/
}

@media(min-width: 0em) and (max-width:48em) {
    .session-v3-results-filter-col1 {
        display: block;
        width: 100%;
    }

    .session-v3-results-filter-col2 {
        display: block;
        width: 100%;
        text-align: left;
    }
}

@media(min-width: 0em) and (max-width:64.375em) {

    .sessions-v3-days-header-append > div:first-child {
        width: 100%;
    }

    .sessions-v3-days-header-append > div:not(:first-child) {
        width: 22%;
    }

    .sessions-v3-days-header div.sessions-v3-button-container {
        margin-right: .5rem;
    }

    .session-v3-button {
        width: 100%;
    }

    .sessions-v3-days-header-append {
        justify-content: center;
    }

    .session-v3-search-col1 {
        width: 100%;
        text-align: center;
    }

    .session-v3-search-col2 {
        /*text-align: left;*/
        width: 100%;
        text-align: center;
        margin-top: 15px;
    }

    a.session-v3-filter-link {
        font-size: 20px;
    }

    .button.small.session-v3-button-text-filter,
    input[type="button"].small.session-v3-button-text-filter {
        font-size: 20px;
    }

    .session-v3-checkboxes td [type="radio"]:not(:checked) + label:before,
    .session-v3-checkboxes td [type="radio"]:checked + label:before {
        top: 7px;
    }

    .session-v3-checkboxes td [type="radio"] + label {
        color: white;
        font-size: 20px;
    }

    .session-v3-checkboxes td [type="checkbox"] + label {
        color: white;
        font-size: 20px;
    }

    .session-v3-filter-flex .session-v3-filter-grade {
        order: 1;
        width: 50%;
        font-size: 20px;
    }

    .session-v3-filter-flex .session-v3-filter-other {
        margin-top: 15px;
        order: 3;
        width: 100%;
        flex-basis: 100%;
        font-size: 20px;
    }

    .session-v3-filter-flex .session-v3-filter-apply {
        order: 2;
        width: 50%;
        font-size: 20px;
    }
}