









@font-face {
    font-family: 'Roboto';
    src: url('../fonts/roboto-regular-webfont.woff2') format('woff2'),
         url('../fonts/roboto-regular-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Roboto';
    src: url('../fonts/roboto-italic-webfont.woff2') format('woff2'),
         url('../fonts/roboto-italic-webfont.woff') format('woff');
    font-weight: normal;
    font-style: italic;
}

@font-face {
    font-family: 'Roboto';
    src: url('../fonts/roboto-bold-webfont.woff2') format('woff2'),
         url('../fonts/roboto-bold-webfont.woff') format('woff');
    font-weight: bold;
    font-style: normal;
}

@font-face {
    font-family: 'Roboto';
    src: url('../fonts/roboto-bolditalic-webfont.woff2') format('woff2'),
         url('../fonts/roboto-bolditalic-webfont.woff') format('woff');
    font-weight: bold;
    font-style: italic;
}

/* Font applied to all elements */
body {
    font-family: 'Roboto', 'Helvetica Neue', Helvetica, Arial, sans-serif !important;
}

/* Fix issues with text-transform affecting placeholders */
::-webkit-input-placeholder {
    text-transform: initial;
}

:-moz-placeholder {
    text-transform: initial;
}

::-moz-placeholder {
    text-transform: initial;
}

:-ms-input-placeholder {
    text-transform: initial;
}



/* Bootstrap Default Styling Customizations */


/*
Default Breakpoints:
XL: @media (min-width: 1200px)
LG: @media (min-width: 992px)
MD: @media (min-width: 768px)
SM: @media (min-width: 576px)
XS: @media (max-width: 575px);

Custom breakpoints:
@media (min-width: 1200px)
*/


/* Default .container width to 100% at LG Viewport and less */

@media (max-width: 1200px) {
    .container {
        max-width: 100%;
    }
}


/* Custom Bootstrap Responsive Style Classes */

@media (max-width: 575px) {
    .h5-xs {
        font-size: 1rem;
    }
}

@media (min-width: 576px) and (max-width: 767px) {
    .h5-sm {
        font-size: 1.125rem;
    }
}


a {
    color: #ED1E36;
}

a:hover,
a:focus {
    color: #fc384f;
}

/* Bootstrap Button Styling */

.btn {
    /*-moz-box-shadow: inset 0 1px 0 rgba(255,255,255,0.5) !important;
-webkit-box-shadow: inset 0 1px 0 rgba(255,255,255,0.5) !important;
box-shadow: inset 0 1px 0 rgba(255,255,255,0.5) !important;*/
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    border-radius: 10px;
}

.btn-primary {
    color: #fff;
    background-color: #ED1E36;
    border: none;
}

.btn-primary:hover{
    color: #fff;
    background-color: #fc384f;
    border: none;
}

.btn-primary.focus,
.btn-primary:focus {
    color: #fff;
    background-color: #fc384f;
    border: none;
    box-shadow: 0 0 0 0.15rem rgba(0, 123, 255, .80);
}

.btn-primary:not(:disabled):not(.disabled).active,
.btn-primary:not(:disabled):not(.disabled):active,
.show>.btn-primary.dropdown-toggle {
    color: #fff;
    background-color: #ED1E36;
    border: none;
}

.btn-primary.disabled,
.btn-primary:disabled,
.btn-primary.disabled:hover,
.btn-primary:disabled:hover {
    color: #6c6c6c;
    background-color: #bebebe;
    border: none;
    cursor: not-allowed;
}

.btn-secondary {
    color: #fff;
    background-color: #666666;
    border: none;
}

.btn-secondary:hover {
    color: #fff;
    background-color: #757575;
    border: none;
}

.btn-secondary:focus,
.btn-secondary.focus {
    color: #fff;
    background-color: #757575;
    border: none;
    box-shadow: 0 0 0 0.15rem rgba(0, 123, 255, .80);
}

.btn-secondary:not(:disabled):not(.disabled).active,
.btn-secondary:not(:disabled):not(.disabled):active,
.show>.btn-secondary.dropdown-toggle {
    color: #fff;
    border: none;
    border-color: #4e555b;
}

.btn-neutral {
    color: #fff;
    background-color: #666666;
    /*background-color: #006692;*/
    border: none;
}

.btn-neutral:hover,
.btn-neutral:focus {
	color: #fff;
	background-color: #fc384f;
	box-shadow: 0 0 0 0.15rem rgba(0,123,255,.80);
}

.btn-neutral:hover {
    color: #fff;
    background-color: #757575;
    /*background-color: #0288c4;*/
    border: none;
}

.btn-primary:focus,
.btn-neutral:focus,
.form-control:focus,
table tr:focus {
    box-shadow: 0 0 0 0.2rem rgba(251, 92, 92, .5);
}

.btn-primary:focus,
.form-control:focus {
    border: none;
}

/* Custom XL Button Size */

.btn-group-xl>.btn,
.btn-xl {
    padding: 3rem 1rem;
    font-size: 1.25rem;
    line-height: 1.5;
    /*border-radius: .3rem;*/
}


/* Custom XS Button Size */

.btn-group-xs>.btn,
.btn-xs {
    padding: .3rem .4rem;
    font-size: .8rem;
    line-height: .5;
    border-radius: .2rem;
}


/* Disabled button style fixes */

.btn[disabled]:hover,
.btn.disabled:hover {
    cursor: not-allowed;
}



/* Other Bootstrap Default Style Overrides */

.text-primary {
    color: #ED1E36 !important;
}

.text-secondary {
    color: #191919 !important;
}

.bg-disabled {
    background-color: #e9ecef;
}

.tooltip {
    font-size: 12px !important;
}

.tooltip-inner {
    min-width: 100px;
    width: 96%;
    max-width: 1014px;
    margin: 0 auto;
}

/* Custom Spinner Size */
.spinner-border-md {
    vertical-align: text-bottom;
    width: 21px;
    height: 21px;
    border-width: 2px;
}

.spinner-border-md2 {
    vertical-align: text-bottom;
    width: 19px;
    height: 19px;
    border-width: 2px;
}

/* arrange popovers below modal overlays - requires container attribute be defined for popovers within modals! */
.popover {
    z-index: 1030;
}

.popover.error {
    max-width: 96%;
    font-size: .75rem;
    background-color: #FFADAD;
    text-align: center;
}

.error.bs-popover-auto[x-placement^=bottom] .arrow:after,
.error.bs-popover-bottom .arrow:after {
    border-bottom-color: #FFADAD;
}

.error.bs-popover-auto[x-placement^=top] .arrow:after,
.error.bs-popover-top .arrow:after {
    border-top-color: #FFADAD;
}

.popover.error .popover-body {
    padding: .25rem .375rem;
}


/* Custom 'width' classes (for buttons) */

.w-150px {
    width: 100%;
    max-width: 150px !important;
}

.w-175px {
    width: 100%;
    max-width: 175px !important;
}

.w-200px {
    width: 100%;
    max-width: 200px !important;
}

.w-225px {
    width: 100%;
    max-width: 225px !important;
}

.w-250px {
    width: 100%;
    max-width: 250px !important;
}


/* Fix issue with Bootstrap Modal Windows and Navigation Bar Content Shift */

html {
    overflow-y: scroll !important;
}

html.noscroll {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
    height: 100%;
    overflow-y: scroll !important;
}

.modal-open .modal {
    padding-right: 0 !important;
}

.modal-open[style] {
    padding-right: 0px !important;
}

/*
.modal::-webkit-scrollbar {
width: 0 !important;
}
*/

/* Fix double scrollbar issue in Chrome when modal displayed with scrollable body (above used to work but no longer) */
.modal-open .modal {
    overflow-y: hidden;
}

/* Fix slow scrolling on iOS */
.modal {
    -webkit-overflow-scrolling: touch;
}

/* Add Y Scrollbar to modal-body */
.modal-body {
    overflow-y: auto !important;
}

/* Various Bootstrap CSS Overrides */

/* Add box-shadow to .form-control elements within form-group elements on focus -- more for radiobutton / checkboxes */
/*.form-group:focus-within .form-control:not(.jstree-search-field), */
.form-control input[type="radio"]:focus,
.form-control input[type="checkbox"]:focus {
    box-shadow: 0 0 0 0.15rem rgba(0, 123, 255, .80);
}



/* Loading Spinner (displaySpinner function) */
/* Based on: https://www.w3schools.com/howto/howto_css_loader.asp */

#spinner {
    border: 30px solid #f3f3f3;
    border-radius: 50%;
    border-top: 30px solid #fc384f;
    width: 100%;
    height: 100%;
    -webkit-animation: spin 2s linear infinite;
    /* Safari */
    animation: spin 2s linear infinite;
}

#spinner-bg {
    padding: 30px;
    width: 250px;
    height: 250px;
    background-color: #2a2a2a;
    position: relative;
    top: 50%;
    left: 50%;
    -webkit-transform: translateY(-50%) translateX(-50%);
    -moz-transform: translateY(-50%) translateX(-50%);
    -ms-transform: translateY(-50%) translateX(-50%);
    -o-transform: translateY(-50%) translateX(-50%);
    transform: translateY(-50%) translateX(-50%);

    /* IE 8 */
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=80)";
    /* IE 5-7 */
    filter: alpha(opacity=80);
    /* Netscape */
    -moz-opacity: 0.8;
    /* Safari 1.x */
    -khtml-opacity: 0.8;
    /* Good browsers */
    opacity: 0.8;
    border: 1px solid #9f9f9f;
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    -moz-box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.5);
    -webkit-box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.5);
    box-shadow: inset 0 -1px 0 rgba(255, 255, 255, 0.5);
    cursor: wait;
}

@media (min-width: 576px) and (max-width: 767px) {
    #spinner {
        border: 20px solid #f3f3f3;
        border-top: 20px solid #ED1E36;
    }

    #spinner-bg {
        padding: 20px;
        width: 200px;
        height: 200px;
    }
}

@media (max-width: 575px) {
    #spinner {
        border: 15px solid #f3f3f3;
        border-top: 15px solid #ED1E36;
    }

    #spinner-bg {
        padding: 10px;
        width: 150px;
        height: 150px;
    }
}

#spinner-overlay {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 9999999988 !important;
    color: transparent;
    background-color: rgba(255, 255, 255, 0.4);
    cursor: wait;
}


/* Safari */

@-webkit-keyframes spin {
    0% {
        -webkit-transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
    }
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}



/* Internet Explorer 10/11 Specific CSS Fixes */
@media all and (-ms-high-contrast: none),
(-ms-high-contrast: active) {

    /* Fix flexbox for navbar */
    #header-top,
    #header-bottom {
        display: flex;
        /* new; forces all children into a single row */
        flex-direction: column;
        height: 100%;
    }

    nav.navbar {
        height: 100%;
        display: inline-flex;
        /* justify-content: center; <-- not needed */
        align-items: center;
        width: 100%;
    }

    /* Fix partners page flexbox width for card-body elements */
    #content.partners .card,
    #content.partners .card .card-body {
        /*max-width: 538px;*/
        width: 100%;
    }

    /* Fix card/carddeck fluid image issue -- fixed via adding h-100 class to these elements directly
.card-deck .card {
height: 100%;
}
.card-deck .card .card-img-top {
height: 100%;
}*/

    /* Fix positioning/overlay issue with progress-bar text in header stats areas */
    #header-banner-stats-data .progress span,
    #header-banner-stats-collapse .progress span {
        line-height: 14px !important;
        left: 0px !important;
    }

    /* Fix modal-title width issue in IE10/11 */
    .modal-title {
        width: 100%;
    }
}


/* Bootstrap4-toggle css fixes (https://gitbrent.github.io/bootstrap4-toggle/) */
.toggle .toggle-group {
    left: -1px;
}


/* TiTaToggle CSS overrides (http://kleinejan.github.io/titatoggle/) */
.checkbox-slider input[type="checkbox"]:focus+*:before,
.checkbox-slider--default input[type="checkbox"]:focus+*:before,
.checkbox-slider--a-rounded input[type="checkbox"]:focus+*:before,
.checkbox-slider--a input[type="checkbox"]:focus+*:before,
.checkbox-slider--b input[type="checkbox"]:focus+*:before,
.checkbox-slider--b-flat input[type="checkbox"]:focus+*:before,
.checkbox-slider--c input[type="checkbox"]:focus+*:before,
.checkbox-slider--c-weight input[type="checkbox"]:focus+*:before,
.checkbox-toggle input[type="checkbox"]:focus+*:before {
    outline: none;
    box-shadow: 0 0 0 0.15rem rgba(0, 123, 255, .80);
}

.checkbox-slider--b input:checked+span:before,
.checkbox-slider--b-flat input:checked+span:before {
    background: #fc384f;
}

.checkbox-slider label span,
.checkbox-slider--default label span,
.checkbox-slider--a-rounded label span,
.checkbox-slider--a label span,
.checkbox-slider--b label span,
.checkbox-slider--b-flat label span,
.checkbox-slider--c label span,
.checkbox-slider--c-weight label span {
    line-height: 12px;
    vertical-align: text-top;
}

.checkbox-slider--b input+span,
.checkbox-slider--b-flat input+span,
.checkbox-slider--c input+span,
.checkbox-slider--c-weight input+span {
    padding-left: 30px;
}


.checkbox-slider-sm label span {
    font-size: 10px;
    line-height: 10px;
}

.checkbox-slider-sm input+span {
    padding-left: 10px;
}

/*
.checkbox-slider-md label span {
font-size: 30px;
line-height: 30px;
}

.checkbox-slider-lg label span {
font-size: 40px;
line-height: 40px;
}*/

/* Fix disabled color changed in update */
.checkbox-slider--a input:disabled+span,
.checkbox-slider--a-rounded input:disabled+span,
.checkbox-slider--b input:disabled+span,
.checkbox-slider--b-flat input:disabled+span,
.checkbox-slider--c input:disabled+span,
.checkbox-slider--c-weight input:disabled+span {
    color: #adb5bd;
}

.checkbox-slider--b input:disabled:checked+span:before,
.checkbox-slider--b-flat input:disabled:checked+span:before,
.checkbox-slider--c input:disabled+span:before,
.checkbox-slider--c input:disabled:checked+span:after,
.checkbox-slider--c-weight input:disabled+span:before,
.checkbox-slider--c-weight input:disabled:checked+span:after,
.checkbox-slider--default input:disabled+span:after {
    background: rgba(100, 100, 100, .2);
}


/* noty plugin related styling */
.noty_message {
    font-size: 12px !important;
}

.noty_bar:after {
    position: absolute;
    bottom: -10px;
    right: -3px;
    float: right;
    content: '\f057';
    font-family: FontAwesome;
    color: #333;
    font-weight: normal;
    font-size: 18px;
}


/* rotating style - used by jstree */
/* Safari and Chrome */
@-webkit-keyframes rotating {
    from {
        -webkit-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    to {
        -webkit-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@keyframes rotating {
    from {
        -ms-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -webkit-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    to {
        -ms-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -webkit-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

.rotating,
li.jstree-open.rotate:before,
li.jstree-closed.rotate:before {
    -webkit-animation: rotating 2s linear infinite;
    -moz-animation: rotating 2s linear infinite;
    -ms-animation: rotating 2s linear infinite;
    -o-animation: rotating 2s linear infinite;
    animation: rotating 2s linear infinite;
}




/* jsTree plugin related styling */

/* set minimum height of jstree element (to match height of bootstrap elements, prior to list init) */
.form-row-tree .form-control {
    min-height: 38px;
}

/* make jsTree anchor links normal font size and color */
.jstree a,
.jstree a:not(.btn):active,
.jstree a:not(.btn):visited {
    font-weight: normal !important;
    color: inherit !important;
    text-decoration: none;
}

/* jstreeadmincheckbox checkbox styling */
.admin-access-checkbox-label {
    font-style: italic;
    font-size: 14px;
    vertical-align: top;
    padding-left: 11px;
    margin-bottom: 0 !important;

}

.all-admin-checkbox-label {
    font-style: italic;
    font-size: 14px;
    vertical-align: top;
    color: firebrick;
    padding-left: 1px;
    margin-bottom: 0 !important;
}

/* Use fontawesome icon for jsTree parent nodes */
li.jstree-open:before {
    display: inline-block;
    /*vertical-align: top;*/
    content: '\f056';
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: inherit;
    color: #fc384f;
    font-weight: normal;
    font-size: 20px;
    width: 20px;
    height: 20px;
    line-height: 20px;
    text-align: center;
}

/* Use fontawesome icon for jsTree parent nodes */
li.jstree-closed:before {
    display: inline-block;
    /*vertical-align: top;*/
    content: '\f055';
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: inherit;
    color: #fc384f;
    font-weight: normal;
    font-size: 20px;
    width: 20px;
    height: 20px;
    line-height: 20px;
    text-align: center;
}

/* Hide/Remove default jstree arrow icons */
.jstree-icon.jstree-ocl {
    background: none !important;
    margin-left: -20px;
}

/* Fix overflow on jstreeGrid wrapper */
.jstree-grid-wrapper {
    overflow: initial !important;
}

/* Hide/Remove jstreeGrid header elements */
.jstree-grid-header {
    display: none !important;
}

/* Remove padding on jstreeGrid cells - Keeps styling consistant with default jsTree padding vs jstreeGrid initalization */
.jstree-grid-cell {
    padding-left: 0 !important;
}

/* Fix jstreeGrid column-0 width */
.jstree-grid-column-0 {
    width: 100% !important;
    max-width: unset !important;
}

/* Fix issue with jsTreeGrid 'admin checkbox' background color being visible when 'normal' jsTree node is selected */
.jstree-clicked:not(.jstree-hovered) {
    background: transparent !important;
    border-radius: none !important;
    box-shadow: none !important;
}

.jstree-clicked.jstree-hovered,
.jstree-default .jstree-hovered {
    background: #e7f4f9 !important;
    border-radius: none !important;
    box-shadow: none !important;
}

/* New method to hide parent node checkboxes by adding a_attr classname to parent nodes / inital json data */
.no-checkbox>i.jstree-checkbox {
    display: none;
}

/* jsTree Search Filter(s) styling */
.jstree-search-group {
    width: auto;
    max-width: 248px;
    float: right;
}

/* Responsive styling for .jstree-search-group element */
@media (max-width: 405px) {
    .jstree-search-group {
        float: unset;
        margin: 2px 0 8px;
    }
}

.jstree-search-field {
    padding: 8px;
}

@media (max-width: 550px) {
    .jstree-search-field {
        width: 100px !important;
    }
}


.jstree-search-group button {
    font-size: 9.5px;
    height: 26px !important;
}

.jstree-search-group button.showSelected {
    border-top-right-radius: 4px !important;
    border-bottom-right-radius: 4px !important;
    background-color: #6c757d;
}

.jstree-search-group button:focus {
    box-shadow: 0 0 0 0.15rem rgba(0, 123, 255, .80);
}

.jstree-search-group .badge {
    position: absolute;
    margin-top: -15px;
    font-size: 11px;
    height: 100%;
    display: none;
}

.jstree-search-field {
    /*width: 50% !important;*/
    font-size: 12px;
    min-height: 26px !important;
    height: 26px !important;
    z-index: 1;
}

.jstree-search-field:focus {
    box-shadow: 0 0 0 0.15rem rgba(0, 123, 255, .80);
}

.jstree-default .jstree-search {
    font-style: inherit;
    color: inherit;
    font-weight: inherit;
    background-color: #ffff80 !important;
}

/* add strike through text of disabled jstree node  */
.jstree-anchor.jstree-disabled {
    /* IE 8 */
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
    /* IE 5-7 */
    filter: alpha(opacity=50);
    /* Netscape */
    -moz-opacity: 0.5;
    /* Safari 1.x */
    -khtml-opacity: 0.5;
    /* Good browsers */
    opacity: 0.5;
}



/* jquery.loadmask.min.js plugin css overrides  */

/* hidden div used for loading mask text and image - found in header */

#loading-mask {
    display: none;
}

.loadmask {
    z-index: 100;
    position: absolute;
    top: 0;
    left: 0;
    /* IE 8 */
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)" !important;
    /* IE 5-7 */
    filter: alpha(opacity=50) !important;
    /* Netscape */
    -moz-opacity: 0.5 !important;
    /* Safari 1.x */
    -khtml-opacity: 0.5 !important;
    /* Good browsers */
    opacity: 0.5 !important;
    background-color: #333 !important;
    width: 100%;
    height: 100%;
    zoom: 1;
    cursor: wait;
}

.loadmask-msg {
    z-index: 20001;
    position: absolute;
    top: 5% !important;
    left: 10% !important;
    border: none !important;
    background: transparent !important;
    padding: 0;
    width: 80%;
    text-align: center;
    margin: 0;
}

.loadmask-msg div {
    padding: none;
    background: transparent !important;
    line-height: 16px;
    border: none;
    color: #FFF;
    font: inherit !important;
    font-size: 20px !important;
    cursor: wait;
    filter: glow(color=black, strength=1);
    text-shadow: -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000;
}


/* Tempus Dominus Bootstrap4 Datepicker plugin CSS Overrides */
.bootstrap-datetimepicker-widget.dropdown-menu {
    min-width: 100%;
    left: 0 !important;
    z-index: 2000 !important;
}

/* Common Page Elements */

/* hide IE10 > password clear/reveal icon */
::-ms-clear,
::-ms-reveal {
    display: none;
}

/* remove outline for links and buttons - firefox fix */
:focus {
    outline: none;
}

::-moz-focus-inner {
    border: 0;
}

a:not(.btn),
a:not(.btn):active,
a:not(.btn):visited {
    text-decoration: none;
    color: #fc384f;
    font-weight: bold;
}

a:not(.btn):hover {
    text-decoration: none;
    color: #111111;
    font-weight: bold;
}

a:not(.btn):focus {
    text-decoration: underline !important;
    color: #111111 !important;
    font-weight: bold;
}

#content-top-hr,
.primary-hr {
    height: 3px;
    margin-top: 2px;
    background-color: #565656;
}

.primary-color {
    color: #ED1E36;
}

#content {
    margin-top: 20px;
}

#content h1 {
    font-size: 22px;
    font-weight: 700;
    text-transform: uppercase;
    text-indent: 0px;
    color: #ED1E36;
}

#content:after {
    content: '';
    display: block;
    clear: both;
}

.ribbon-hr {
    font-size: 22px;
    font-weight: 400;
    line-height: 1.5;
    margin-bottom: 0;
    position: relative;
    display: inline-block;
    background: #ED1E36;
    min-height: 42px;
    /*line-height: 42px;*/
    padding: 5px 20px;
    width: 50%;
    min-width: 430px;
    color: #FFF;
    text-transform: uppercase;
    text-align: left;
    /* rounded right corner */
    -webkit-border-top-right-radius: 90px;
    -webkit-border-bottom-right-radius: 90px;
    -moz-border-radius-topright: 90px;
    -moz-border-radius-bottomright: 90px;
    border-top-right-radius: 90px;
    border-bottom-right-radius: 90px;
}

/*
#content:not(.registration) .ribbon-hr {
margin-bottom: 20px;
}*/

/* Responsive styling for ribbon elements */
@media (max-width: 500px) {
    .ribbon-hr {
        font-size: 18px;
        min-width: 100%;
        padding: 7px;
        /* remove rounded right corner */
        -webkit-border-top-right-radius: unset;
        -webkit-border-bottom-right-radius: unset;
        -moz-border-radius-topright: unset;
        -moz-border-radius-bottomright: unset;
        border-top-right-radius: unset;
        border-bottom-right-radius: unset;
    }
}

.question-box {
    font-size: 19px;
    font-weight: bold;
    margin: 40px auto 30px auto !important;
    text-align: center;
    border: solid 1px #111111;
    color: #FFF;
    min-height: 42px;
    line-height: 1.5;
    padding: 7.5px;
    background: #333333;
    /* rounded right corner */
    -webkit-border-top-right-radius: 90px;
    -webkit-border-bottom-right-radius: 90px;
    -moz-border-radius-topright: 90px;
    -moz-border-radius-bottomright: 90px;
    border-top-right-radius: 90px;
    border-bottom-right-radius: 90px;
    /* rounded left corner */
    -webkit-border-top-left-radius: 90px;
    -webkit-border-bottom-left-radius: 90px;
    -moz-border-radius-topleft: 90px;
    -moz-border-radius-bottomleft: 90px;
    border-top-left-radius: 90px;
    border-bottom-left-radius: 90px;
}

#content:not(.registration) .question-box {
    margin: 20px auto !important;
}

/* Responsive styling for question-box elements */
@media (max-width: 500px) {
    .question-box {
        font-size: 17px;
    }
}

.container>.ajax-content~.ajax-content {
    display: none;
}

.ajax-content .question-box {
    width: 90%;
    height: auto;
    margin: 0 auto;
    text-align: center;
    margin-bottom: 20px;
}

.ajax-content table {
    width: 90%;
    margin: 0 auto 1rem auto;
}

table .selected-row {
    /*background-color: #FFFF4F !important;*/
    background-color: #fc384f !important;
    color: #fff !important;
}

table .selected-row:hover {
    color: #000 !important;
}

table td.selected-row:last-of-type:after {
    content: "\f00c";
    font-family: FontAwesome;
    font-style: normal;
    text-decoration: inherit;
    color: #13D522;
    font-weight: normal;
    font-size: 50px;
    margin-left: -50px;
    margin-top: -25px;
    margin-bottom: -26px !important;
    position: relative;
    float: right;
    right: -30px;
    z-index: 10;
    opacity: 2.2;
    filter: glow(color=black, strength=1);
    text-shadow: -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000;
}

.strikethrough {
    font-style: italic;
    text-decoration: line-through;
}

.mandatory-field-message {
    font-size: 13px;
    color: #fc384f;
    display: block;
    font-style: italic;
    margin-top: 12px;
    margin-left: 10px;
    margin-bottom: -22px;
}

.form-row-label-mandatory {
    font-size: 16px;
    margin: -8px 0px 0px -2px;
    color: #fc384f;
}


.form-group.validation-error,
.text-red {
    color: #eb0000;
}


/* Header & Nav Menu Styling */

#header-top,
#header-bottom {
    background-color: #ED1E36;
}

#header-top {
    border-bottom: solid 3px #565656;
}

#header.pre-login #header-top {
    min-height: 66px;
}

#header .navbar {
    min-height: 63px;
}

#header .navbar-toggler {
    color: rgba(255, 255, 255, .5);
    border-color: rgba(255, 255, 255, .1);
    background-color: rgba(84, 195, 229, 0.2);
}

#header .nav-link {
    text-transform: uppercase;
    font-weight: normal;
    color: #fff;
}

#header .nav-link:hover {
    color: #fc384f;
}

#header .nav-link:focus {
    color: #fc384f;
     !important;
}

#header .nav-item.active .nav-link {
    color: #565656 !important;
    font-weight: bold;
    /*min-width: 150.5px;*/
}

#header .nav-link.disabled {
    color: #6c757d;
    cursor: not-allowed;
}

#header .navbar ul li:not(:last-child) {
    border-right: 1px solid grey;
}

.nav-link,
.nav-link:active,
.nav-link:visited {
    font-weight: normal !important;
    color: #fc384f;
}

.nav-pills .nav-link.active,
.nav-pills .show>.nav-link {
    background-color: #fc384f;
}

#skipToContentBtn {
    position: absolute;
    top: -1px;
    margin-left: 2px;
    text-transform: uppercase;
    font-size: 10px;
    z-index: 1;
}

#navbar-header-top-left {
    max-width: 451.5px;
}

#navbar-header-top-right {
    max-width: 451.5px;
}

#navbar-header-top-middle {
    max-width: 230px !important;
}

#header-bottom-text {
    color: #BFBFBF;
    vertical-align: middle;
    line-height: 31px;
    min-height: 31px;
    text-align: center;
    font-size: 13px;
}

.header-bottom-text-hover {
    color: #FFF !important;
    cursor: pointer;
}

#header-banner {
    height: 180px;
    background-image: url('../../../../contents/images/generic/header-banner-pre-login.jpg');
    background-repeat: no-repeat;
    background-position: center left;
    background-size: cover;
    position: relative;
}

#header.post-login #header-banner {
    background-image: url('../../../../contents/images/generic/header-banner-post-login.jpg');
}

#header-banner-stats {
    display: none;
    position: absolute;
    top: 0;
    right: 0;
    text-align: left;
    width: 100%;
    /* width is dynamically changed via header-menu.js function */
    max-width: 275px;
    height: 180px;
    line-height: 180px;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#000000+0,000000+40&0+0,0.65+40 */
    background: -moz-linear-gradient(left, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.85) 90%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(left, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.85) 90%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.85) 90%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#000000d9', GradientType=1);
    /* IE6-9 */
}

#header-banner-stats-collapse {
    display: inline-block;
    width: calc(50% - 115px);
    text-align: right;
    padding: 5px 20px 0 0;
    text-transform: uppercase;
    line-height: 15px;
}

#header-banner-stats-collapse .fullname {
    font-size: 13px;
    font-weight: bolder;
    word-wrap: break-word;
    white-space: pre-line;
    color: #fff;
}

#header-banner-stats-collapse .username {
    font-size: 10.5px;
    font-weight: bold;
    color: #a5a5a5;
    white-space: nowrap;
    text-transform: lowercase;
    font-style: italic;
    word-break: break-all;
    white-space: pre-line;
}

@media (max-width: 650px) {
    #header-banner-stats-collapse .fullname {
        font-size: 12px;
    }

    #header-banner-stats-collapse .username {
        font-size: 10px;
        line-height: 11px;
    }
}

@media (max-width: 620px) {
    #header-banner-stats-collapse .fullname {
        font-size: 11px;
    }

    #header-banner-stats-collapse .username {
        font-size: 9.5px;
    }
}

@media (max-width: 550px) {
    #header-banner-stats-collapse .fullname {
        font-size: 10px;
    }

    #header-banner-stats-collapse .username {
        font-size: 9px;
    }
}

#header-banner-stats-collapse .badge {
    font-size: 9px !important;
}

#header-banner-stats-collapse .progress {
    float: right;
    width: 90%;
    max-width: 80px;
    color: #212529;
    text-shadow: none !important;
    background-color: #d5d5d5;
    height: 13.3px;
    margin-top: 2px;
}

#header-banner-stats-collapse .progress span {
    text-shadow: none !important;
    font-size: 9px !important;
    font-weight: bold;
    line-height: 13.3px;
}

#header-banner-stats-collapse .dropdown-toggle:after {
    content: none;
}

#header-banner-stats-collapse .dropdown-menu {
    left: unset;
    right: -19px;
    top: 54px;
}

#header-banner-stats-collapse .dropdown-menu .stats {
    font-size: 8.5px;
    padding: 5px 5px 0 5px;
    margin: 5px 5px 0 5px;
    border-top: 1px dotted gray;
    color: gray;
    white-space: nowrap;
    text-align: center;
}

#header-banner-stats-collapse a.dropdown-item {
    text-align: right;
}


@media (min-width: 992px) {
    #header-banner-stats {
        display: block;
    }

    #header-banner-stats-collapse {
        display: none;
    }
}

@media (max-width: 450px) {
    #header-banner-stats-collapse {
        display: none;
    }

    .navbar-toggler {
        padding: .35rem;
        margin-left: 5px !important;
    }

    #header-bottom .navbar {
        min-height: 36px !important;
    }
}

#header-banner-stats-data:hover {
    cursor: pointer;
}

#header-banner-stats-data {
    display: inline-block;
    vertical-align: middle;
    line-height: normal;
    white-space: normal;
    text-transform: uppercase;
    text-align: right;
    color: #fff;
    width: 90%;
    font-size: 9px;
    line-height: 15px;
    text-shadow: 0.5px 0.5px rgba(0, 0, 0, 0.8);
}

#header-banner-stats-data .fullname {
    font-size: 18px;
    line-height: 18px;
    font-weight: bolder;
    word-wrap: break-word;
    color: #fff;
}

#header-banner-stats-data .username {
    font-size: 10.5px;
    font-weight: bold;
    color: #a5a5a5;
    white-space: nowrap;
    margin-bottom: 15px;
    text-transform: lowercase;
    font-style: italic;
}

#header-banner-stats-data .badge {
    background-color: #006fe6;
    font-size: 11px !important;
    text-shadow: none !important;
}

#header-banner-stats-data .progress {
    width: 125px;
    left: 125px;
    color: #212529;
    text-shadow: none !important;
    background-color: #d5d5d5;
    margin-top: -1px;
}

#header-banner-stats-data .progress span {
    font-size: 11px !important;
    font-weight: bold;
    text-shadow: none !important;
    line-height: 16px;
    margin-top: 1px;
}

#header-banner-stats-data .stat {
    color: #d5d5d5;
}

#header-banner-text {
    white-space: nowrap;
    position: relative;
    top: 50px;
    text-shadow: transparent 0px 0px 0px, #000 1px 2px 1px;
}

#header-banner-text-small {
    font-size: 26px;
    line-height: 32px;
    color: #FFFFFF;
    text-align: center;
    /*background-image: url('/koala_mpp/contents/images/generic/activityleader/header-banner-text-small.png');*/
    background-repeat: no-repeat;
    background-position: center;
}

#header-banner-text-small-lower {
    font-size: 23px;
    line-height: 23px;
    color: #FFFFFF;
    text-align: center;
}

#header-banner-text-large {
    font-weight: 700;
    font-size: 44px;
    line-height: 44px;
    color: #FFF;
    text-align: center;
    color: #FFFFFF;
}

/* Responsive styling for header-banner-text-large */
@media (max-width: 1090px) {
    #header-banner-text-large {
        font-size: 40px;
    }
}

@media (max-width: 985px) {
    #header-banner-text-large {
        font-size: 36px;
    }
}

@media (max-width: 880px) {
    #header-banner-text-large {
        font-size: 30px;
    }
}

@media (max-width: 750px) {
    #header-banner-text-large {
        font-size: 26px;
    }
}

@media (max-width: 650px) {
    #header-banner-text-large {
        font-size: 24px;
    }
}

@media (max-width: 600px) {
    #header-banner-text-large {
        font-size: 22px;
    }
}

@media (max-width: 550px) {
    #header-banner-text-large {
        font-size: 20px;
    }
}

@media (max-width: 500px) {
    #header-banner-text-large {
        font-size: 18px;
    }
}

@media (max-width: 450px) {
    #header-banner-text-large {
        font-size: 16px;
    }
}

/* add partner logo image to pre-login header bottom area
#header.pre-login #header-bottom-partners {
min-height: 58px;
background-image: url('../../../../contents/images/generic/header-banner-partners.png');
background-repeat: no-repeat;
background-position: center;
background-size: contain
}*/

#header-banner-partners-overlay {
    display: none;
    /* mpp requested this be removed */
    position: absolute;
    top: 0;
    right: 0;
    text-align: left;
    width: 100%;
    max-width: 230px;
    height: 180px;
    line-height: 180px;
    background: -moz-linear-gradient(left, rgba(0, 0, 0, 0) 0%, rgba(51, 51, 51, 0.90)) 40%);
    background: -webkit-linear-gradient(left, rgba(0, 0, 0, 0) 0%, rgba(51, 51, 51, 0.90) 40%);
    background: linear-gradient(to right, rgba(0, 0, 0, 0) 0%, rgba(51, 51, 51, 0.90) 40%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00000000', endColorstr='#333333', GradientType=1);
}

@media (max-width: 1100px) {
    #header-banner-partners-overlay {
        max-width: 200px;
    }
}

@media (max-width: 825px) {
    #header-banner-partners-overlay {
        max-width: 180px;
    }
}

@media (max-width: 800px) {
    #header-banner-partners-overlay {
        max-width: 150px;
    }
}

@media (max-width: 650px) {
    #header-banner-partners-overlay {
        max-width: 125px;
    }
}

#header-banner-partners-logo {
    width: 100%;
    height: 100%;
    background-image: url('/koala_mpp/contents/images/generic/partners-logo.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}



#header-logo {
    width: 247px;
    height: 125px;
    background-image: url('/koala_mpp/contents/images/generic/header-logo-bg.png');
    background-repeat: no-repeat;
    position: absolute;
    top: 0px;
    /* center image dynamically based on header width minus half of header-logo-bg image width */
    left: 50.25%;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    transform: translateX(-50%);
}

#header-logo-img {
    /*display: inline-block;*/
    margin-left: 6px;
    background-color: #fff;
    margin-right: 12px;
}

/* Bootstrap Carousel style for header-logo-image */
#header-logo-img .carousel-item {
    width: 228px !important;
    height: 82px !important;
    margin-top: 6px !important;
    background-position: top center !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-color: #fff !important;
    /* Needed for fade transition to work with background-image */
}

#header-logo-img .carousel-item:hover {
    cursor: pointer;
}

/* Responsive styling for header elements */
@media (max-width: 485px) {
    #header-banner-text {
        top: 60px;
    }

    #header-banner-text-small {
        font-size: 22px;
        background-size: contain;
    }

    #header-banner-text-small-lower {
        font-size: 19px;
    }
}

@media (max-width: 330px) {
    #header-banner-text-small {
        font-size: 20px;
        background-size: contain;
    }

    #header-banner-text-small-lower {
        font-size: 17px;
    }
}


/* programPageLogo styling - added for MPP to make images smaller at responsive breakpoint */

@media (max-width: 767px) {
    .programPageLogo {
        height: 58px !important;
    }
}


/* Footer (footer-pre.jsp) Styling */

#footer-top {
    background-color: #333333;
    width: 100%;
    height: 23px;
    margin-top: 10px;
    color: #CCC;
}

#footer-bottom {
    padding: 5px;
    width: 100%;
    text-align: right;
    font-size: 12px;
    font-weight: bold;
    color: #333;
}

#footer a {
    text-decoration: none;
    color: inherit;
}

#footer a:hover,
#footer a:focus {
    color: #191919 !important;
}

#footer-top #footer-top-left {
    display: inline-block;
    float: left;
    font-size: 12px;
    font-weight: bold;
    padding-left: 2.5px;
    margin-top: 2.5px;
}

#footer-top #footer-top-left button:before {
    display: inline-block;
    content: '\f05a';
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: inherit;
    color: inherit;
    font-weight: normal;
    font-size: 12px;
    margin-right: 5px;
}

#footer-top #footer-top-right {
    display: inline-block;
    float: right;
    font-size: 12px;
    font-weight: bold;
    padding-right: 2.5px;
    margin-top: 2.5px;
}

#footer-top #footer-top-right button:after {
    display: inline-block;
    content: '\f024';
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: inherit;
    color: inherit;
    font-weight: normal;
    font-size: 12px;
    margin-left: 5px;
}

#footer-top #footer-top-right:hover,
#footer-top #footer-top-right:hover:before,
#footer-top #footer-top-left:hover,
#footer-top #footer-top-left:hover:after {
    color: #fff;
    cursor: pointer;
}

/* Responsive styling for footer elements */
@media (max-width: 400px) {
    #footer-top #footer-top-left {
        padding-left: 2px;
    }

    #footer-top #footer-top-right {
        padding-right: 2px;
    }
}


/* programPageLogo - used in various pages */
.programPageLogo {
    height: 100px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    background-position: center center !important;
}


/* Start Page (start.jsp) Styling */

.start h2 {
    font-size: 22px;
    font-weight: 700;
    text-transform: uppercase;
    text-indent: 0px;
    color: #ED1E36;
}


/* Registration Page (/registration/registration.jsp) Styling */

body.registration .tooltip {
    z-index: 1000;
}

#googleRecaptcha {
    min-height: 78px;
    margin-bottom: 20px;
}

#googleRecaptcha div:first-child {
    margin: 0 auto;
}

.tooltip.error.recaptcha {
    margin-top: -10px;
}

.privacy-scroll-arrow {
    display: inline-block;
    position: absolute;
    /* was fixed */
    right: 2px;
    top: 12px;
}

.privacy-scroll-arrow-tip {
    width: 0px;
    height: 0px;
    border-style: solid;
    border-width: 18px 15px 0 15px;
    border-color: #fc384f transparent transparent transparent;
    display: inline-block;
    vertical-align: middle;
    margin: 24px 0px 0px 10px;
}

.privacy-scroll-arrow-line {
    position: relative;
    top: -42px;
    left: -6.5px;
    width: 14px;
    height: 30px;
    background-color: #fc384f;
    display: inline-block;
    vertical-align: middle;
}

#privacy-policy h6 {
    margin-bottom: 0.5rem !important;
    line-height: 1.5 !important;
}

.registration-communication-disclaimer {
    max-width: 880px;
    height: auto;
    margin: 0 auto 30px auto;
    text-align: left;
}



/* Home Page (/course/home.jsp) Styling */

@media (min-width: 768px) {
    #content.home .card-deck .card {
        min-width: calc(33% - 30px);
        max-width: calc(33% - 30px);
    }
}

@media (min-width: 576px) and (max-width: 767px) {
    #content.home .card-deck .card {
        min-width: calc(50% - 30px);
        max-width: calc(50% - 30px);
    }
}

#content.home .card-footer {
    background-color: inherit;
    border-top: none;
}

.card.disabled {
    opacity: 0.5;
    background-color: #f4f4f4 !important;
}

#home-page-info h3 {
    font-size: 1rem;
    margin-top: 16px;
    margin-bottom: 1rem;
    line-height: 1.5;
}

#home-page-info ul {
    list-style: none;
    padding: 0;
    margin: 20px 0 0 0;
}

#home-page-info ul li {
    padding-left: 20px;
    padding-bottom: 10px;
    text-indent: -14px;
}

#home-page-info ul li:before {
    content: "● ";
    position: relative;
    top: -1px;
    color: #fc384f;
}


/* Handouts Page (/course/handouts.jsp) Styling */
#handouts-info h3 {
    font-size: 1rem;
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.5;
}

#program-handout-title h4 {
    font-size: 1rem;
    margin-top: 0;
    margin-bottom: 0;
    line-height: 1.5;
}

#handouts .card-header {
    font-size: 1.25rem;
    font-weight: 500;
    line-height: 1.2;
    background-color: rgba(0, 0, 0, .01);
}


/* Acknowledgements Page (/course/acknowledgements.jsp) Styling */
#acknowledgements-info h3 {
    font-size: 1rem;
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.5;
}

#program-acknowledgements-title h4 {
    font-size: 1rem;
    margin-top: 0;
    margin-bottom: 0;
    line-height: 1.5;
    color: #E32526;
}


/* Help Page (/course/help.jsp) Styling */
#help-info h3 {
    font-size: 1rem;
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.5;
}

#help-questions h4 {
    font-size: 1.25rem;
    margin-top: 0;
    margin-bottom: 0;
    line-height: 1.2;
    background-color: rgba(0, 0, 0, .01);
}


/* Partners Page (/course/partners.jsp) Styling */
#partners-info h3 {
    font-size: 1rem;
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.5;
}


/* FAQ Page (/course/faq.jsp) Styling */
#faq-info h3 {
    font-size: 1rem;
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.5;
}

#faq-questions h4 {
    font-size: 1.25rem;
    margin-top: 0;
    margin-bottom: 0;
    line-height: 1.2;
    background-color: rgba(0, 0, 0, .01);
}


/* Payments Pages (/course/payment*.jsp) Styling

#payment-table {
width: 90%;
border-collapse:collapse;
margin: 0 auto;
margin-bottom: 20px;
}

#payment-table td {
border: 1px solid #ED1E36;
background-color: transparent;
padding: 10.5px;
}

#payment-content .ajax-page-buttons {
margin-bottom: 20px;
}

#pre-registration-code-disclaimer {
margin-top: 20px;
text-align: left;
}

.disclaimer-title {
font-size: 22px;
font-weight: bold;
margin-bottom: 20px;
margin-top: 20px;
}

#payment-content .page-content-box ul {
list-style: none;
padding:0;
margin:0;
}

#payment-content .page-content-box ul li {
padding-left: 20px;
padding-bottom: 10px;
text-indent: -14px;
}

#payment-content .page-content-box ul li:before {
content: "● ";
position: relative;
top: -1px;
color: #ED1E36;
}*/

.payment .disclaimer-title {
    font-size: 1rem;
}

.payment #payBtn {
    -webkit-appearance: none;
}


/* Reset-Password Page (/reset-password.jsp) Styling */
#reset-password-recovery-email-content h3,
#reset-password-success-content h3 {
    line-height: 1.5;
}

/* Program Page (/course/program.jsp) Styling */

#program-page-info h3 {
    font-size: 1rem;
    margin-top: 0;
    margin-bottom: 1rem;
    line-height: 1.5;
}

.card.disabled a,
.nav-link.disabled {
    cursor: not-allowed;
}

#program-module-list .card-header {
    background-color: rgba(0, 0, 0, .01);
}

#program-module-list h6 {
    margin-bottom: 0rem;
    line-height: 1.5;
}

.card.completed .card-header:after {
    content: "\f00c";
    font-family: FontAwesome;
    font-style: normal;
    text-decoration: inherit;
    color: #13D522;
    font-weight: normal;
    font-size: 50px;
    margin-bottom: -50px !important;
    position: relative;
    top: -20px;
    float: right;
    right: -10px;
    z-index: 10;
    opacity: 0.6;
    width: auto;
    height: auto;
    filter: glow(color=black, strength=1);
    text-shadow: -1px -1px 0 #000, 1px -1px 0 #000, -1px 1px 0 #000, 1px 1px 0 #000;
}

/* border color for card with active class */

.card.current {
	border-color: #fc384f;
	/* DISABLED css animation due to crashing on Safari / iOS 15.4.1 or greater
    animation-name: card-current;
    animation-duration: 4s;
	animation-iteration-count: infinite; */
    }

/* @keyframes card-current {
	0%   {border-color: rgba(0, 0, 0, 0.125);}
	50%  {border-color: #fc384f;}
	100% {border-color: rgba(0, 0, 0, 0.125);}
}*/

.nav-link.completed {
    z-index: 1;
    position: relative;
}

.nav-link.completed:after {
    content: "\f00c";
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    text-decoration: inherit;
    color: #13D522;
    font-weight: normal;
    font-size: 50px;
    position: absolute;
    left: 29.5px;
    margin-top: -52px;
    z-index: -1;
    opacity: 0.1;
    width: auto;
    height: auto; /* width/height so IE7 and lower will work */  
    filter: glow(color=black, strength=1);
    text-shadow: -1px -1px 0 #000,
        1px -1px 0 #000,
        -1px 1px 0 #000,
        1px 1px 0 #000;
}

#content.program .nav-tabs .nav-link:hover {
    color: #333333 !important;
}

#content.program .nav-tabs .nav-link.show {
    color: #fc384f !important;
}


#content.program .nav-tabs .nav-link.current {
	color: #fc384f;
	border-color: #fc384f #fc384f #fff;
	/* DISABLED due to crashing on Safari / iOS 15.4.1 or greater
    animation-name: tab-current;
    animation-duration: 1s;
	animation-iteration-count: infinite;*/
    }

/*@keyframes tab-current {
	0%   {color: #8b8b8b;}
	50%  {color: #fc384f;}
	100% {color: #8b8b8b;}
} */


/* Survey Modal Styling */

#survey-description {
    font-weight: bold;
    margin-bottom: 20px;
}

#surveyModal table th,
#surveyModal table td:not(:first-child) {
    text-align: center;
    vertical-align: middle;
}

/* method for displaying survey checkboxes and radiobuttons options vertically */

#surveyModal .form-control {
    height: auto !important; /* allows border height around checkboxes to grow with options */
}

#surveyModal .form-group-radio-buttons label {
    display: inline; /* fix with using after css tag to add line break after labels */
    cursor: pointer;
    margin-left: 5px;
}

#surveyModal .form-group-radio-buttons label:after {
    content: "\A"; /* actual line break after labels */
    white-space: pre; /* removes trailing space */
    /* optional method to fix issues in IE but needs padding removed on label:
content: "";
display: block;*/
}

/* audio questions - font-awesome play/stop icon */
#surveyModal a.fa {
    color: #ED1E36;
    display: inline;
}

#surveyModal a.fa:hover {
    color: #fc384f;
    font-weight: normal;
}

#surveyModal a.fa span,
#surveyModal a.fa:hover span {
    color: initial;
    font-weight: initial;
    margin-left: 5px;
}

#surveyModal .form-group.validation-error span {
    color: red !important;
}


/* audio questions - font-awesome play/stop icons in parent card element with bg-danger class (validation error) */
#surveyModal .bg-danger a.fa {
    color: #FFF;
}

/* new font-awesome play icon */
#surveyModal .bg-danger a.fa:hover {
    color: #dddddd;
}

#surveyModal .bg-danger a.fa span,
#surveyModal .bg-danger a.fa:hover span {
    color: #fff !important;
}


/* fix issue with validation scroll to error and default relative positioning on bootstrap card elements */
#surveyModal .card {
    position: unset !important;
}

/* fix styling for lables within card elements and validation-error class */
.card.bg-danger .validation-error {
    color: #fff !important;
}



/* Profile Page / Admin Page Styling */
#profile-statistics,
#admin-statistics,
.program-statistics {
    position: relative;
    font-size: 13px;
}

#profile-info .mandatory-field-message,
#reset-pass .mandatory-field-message {
    margin-top: 0px;
    text-align: right;
    margin-right: 8px;
}

#profile-statistics>.badge,
#admin-statistics>.badge,
.program-statistics>.badge {
    position: absolute;
    top: -5px;
}

.statistic {
    display: inline-block;
    text-align: left;
    padding: 5px 40px 5px 10px;
    vertical-align: top;
}

.statistic span {
    display: block;
    font-weight: bold;
}

@media (min-width: 576px) {
    #certs-and-takeaways .card-deck .card,
    #payment-receipt .card-deck .card {
        min-width: calc(100% - 30px);
        max-width: calc(100% - 30px);
    }
}

@media (min-width: 768px) {
    #certs-and-takeaways .card-deck .card,
    #payment-receipt .card-deck .card {
        min-width: calc(50% - 30px);
        max-width: calc(50% - 30px);
    }
}

.profile .nav-tabs h4 {
    font-size: 1rem;
    line-height: 1.5;
    font-weight: normal;
    margin-bottom: 0;
}

.profile .tab-pane .pb-2 {
    font-size: 1.75rem;
    font-weight: 500;
    line-height: 1.2;
    margin-bottom: .5rem;
    margin-top: 0;
}

.profile .tab-pane .card-subtitle {
    line-height: 1.2;
}

#certificate-card .card-title {
    font-size: 1.25rem;
    font-weight: 500;
    margin-top: 0;
}

#profile-info .pb-2 {
    display: inline-block;
}

#reset-pass .pb-2 {
    display: inline-block;
}

#reset-password-recovery-email-content h3 {
    font-size: 1rem;
    font-weight: 600;
}

#cacAcceptanceLearnMore:focus,
#cacAcceptanceLearnMore:hover {
    border-color: #727272;
    box-shadow: 0 0 0 0.2rem rgba(251, 92, 92, .5);
}

#rgi_cacAcceptance_1:focus,
#rgi_cacAcceptance_1:hover {
    border-color: #727272;
    box-shadow: 0 0 0 0.2rem rgba(251, 92, 92, .5);
}

#rgi_cacAcceptance_0:focus,
#rgi_cacAcceptance_0:hover {
    border-color: #727272;
    box-shadow: 0 0 0 0.2rem rgba(251, 92, 92, .5);
}

.admin .nav-tabs h4 {
    font-size: 1rem;
    line-height: 1.5;
    font-weight: normal;
    margin-bottom: 0;
}

#report-type-tabs h5 {
    font-size: 1rem;
    margin-bottom: 0rem;
    line-height: 1.5;
}