
:root {
    --primary: #e15666;
    --primary-rgb: 225, 86, 102;
    --primary-active: #c03f4e;

    --secondary: #f8ae4b;
    --secondary-rgb: 248, 174, 75;
    --secondary-active: #d8902f;

    --tertiary: #114c76;
    --tertiary-rgb: 17, 76, 118;
    --tertiary-active: #093a5d;

    --quaternary: #053252;
    --quaternary-rgb: 5, 50, 82; 
    --quaternary-active: #001e34;

    --green-400: #66BB6A;
    --green-700: #388E3C;
    --green-800: #2E7D32;
    --green-900: #1B5E20;

    --grey-50: #FAFAFA;
    --grey-100: #F5F5F5;
    --grey-150: #F2F2F2;
    --grey-200: #EEEEEE;
    --grey-250: #E7E7E7;
    --grey-300: #E0E0E0;
    --grey-350: #CDCDCD;
    --grey-400: #BDBDBD;
    --grey-500: #9E9E9E;
    --grey-600: #757575;

    --lightblue-100: #B3E5FC;
    --lightblue-300: #4FC3F7;

    --orange-400: #FFA726;

    --red-100: #FFCDD2;
    --red-200: #EF9A9A;
    --red-300: #E57373;
    --red-400: #EF5350;
    --red-600: #E53935;
    --red-700: #D32F2F;
    --red-800: #C62828;
    --red-900: #B71C1C;

    --radius: 10px;

    --transition: .25s ease;
}

#MainForm {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

#wrapper {
    flex-grow: 1;
}

/*-----------------------------------------------------------------------------------------------*/

h1 {
    margin: 1rem 0rem;
    font-size: 2.5rem;
    line-height: 1.2em;
    color: var(--secondary);
}

#content .container .page_content h1 {
    font-size: 2.25rem;
}

h2 {
    margin: 1rem 0rem;
    font-size: 2rem;
    line-height: 1.2em;
    color: var(--primary);
}

#content .container .page_content h2 {
    font-size: 1.75rem;
}

h3 {
    margin: 1rem 0rem;
    font-size: 1.65rem;
    line-height: 1.2em;
    color: var(--tertiary);
}

h4 {
    margin: 1rem 0rem;
    font-size: 1.35rem;
    line-height: 1.2em;
}

h5 {
    margin: 14px 0px;
    font-size: 1.2rem;
    line-height: 1.2em;
}

h6 {
    margin: 14px 0px;
    font-size: 1.1rem;
    line-height: 1.2em;
}

p {
    margin: 1rem 0rem;
}

.notice {
    clear: both;
    padding: 10px 15px;
    font-weight: 600;
    background-color: #D8D8D8;
}

.notice a {
    text-decoration: underline;
}

h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child,
h5:first-child,
h6:first-child,
p:first-child {
    margin-top: 0px;
}

h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child,
p:last-child {
    margin-bottom: 0px;
}

/*--------------------------------------------*/

a:link,
a:active,
a:visited {
    text-decoration: none;
}

a.btn.btn-primary,
a.btn.btn-danger,
a.btn.btn-warning,
a.btn.btn-info,
a.btn.btn-success {
    color: white;
}

a {
    color: var(--secondary);
    transition: color 0.3s linear;
}

a:focus,
a:hover {
    color: var(--primary);
}

h1 a:not([href]),
h2 a:not([href]),
h3 a:not([href]),
h4 a:not([href]),
h5 a:not([href]),
h6 a:not([href]) {
    color: inherit;
}

h1 a:not([href]):hover,
h2 a:not([href]):hover,
h3 a:not([href]):hover,
h4 a:not([href]):hover,
h5 a:not([href]):hover,
h6 a:not([href]):hover {
    text-decoration: none;
}

a.external_link:after {
    position: relative;
    display: inline-block;
    content: "\e164";
    top: 1px;
    padding-left: 5px;
    font-weight: 400;
    font-style: normal;
    font-size: 0.9em;
    line-height: 1em;
    font-family: 'Glyphicons Halflings';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a.pdf,
a.word,
a.ppt,
a.video,
a.document,
a.audio {
    display: inline-block;
    padding-left: 22px;
}

a.pdf {
    background: url("../../images/pdf.png") left 2px no-repeat;
}

a.word {
    background: url("../../images/icon_doc.png") left 2px no-repeat;
}

a.ppt {
    background: url("../../images/icon_ppt.png") left 2px no-repeat;
}

a.video {
    background: url("../../images/icon_youtube.png") left 2px no-repeat;
}

a.document {
    background: url("../../images/icon_document.png") left 2px no-repeat;
}

a.audio {
    background: url("../../images/icon_audio.png") left 2px no-repeat;
}

.btn_block {
    clear: both;
    display: block;
    float: none;
}

a.link_block {
    clear: both;
    position: relative;
    display: block;
    margin-top: 5px;
    padding: 8px 15px;
    text-decoration: none;
    border-top: 1px solid #d8d8d8;
    border-bottom: 1px solid #d8d8d8;
}

a.link_block:hover {
    background-color: rgba(0, 0, 0, 0.1);
}

a.link_block .glyphicon-chevron-right,
a.link_block_lg .glyphicon-chevron-right,
a.link_block_md .glyphicon-chevron-right,
a.link_block_sm .glyphicon-chevron-right,
a.link_block_xs .glyphicon-chevron-right {
    position: absolute;
    top: 50%;
    right: 10px;
    margin-top: -0.5em;
}

/*--------------------------------------------*/

.btn {
    position: relative;
    padding: 8px 15px;
    margin: 0;
    text-decoration: none !important;
    display: inline-block;
    color: #fff;
    border: 0;
    border-radius: 10px;
    text-align: center;
    cursor: pointer;
    font-size: 1rem;
    line-height: 1.2em;
    z-index: 1;
    text-shadow: none;
    box-shadow: none;
    transition: background .25s ease;
    background: var(--btn-back);
}

.btn:hover,
.btn:focus {
    background: var(--btn-back-active);
    color: #fff !important;
}

.btn:disabled, .btn.disabled {
    background: var(--btn-back);
    opacity: .65;
    cursor: not-allowed;
}

.btn.btn-text {
    background: transparent;
    color: var(--btn-back) !important;
    font-weight: 600;
}

.btn.btn-text:hover,
.btn.btn-text:focus {
    color: var(--btn-back-active);
    background: rgba(200, 200, 200, .25);
}

.btn-primary {
    --btn-back: var(--primary);
    --btn-back-active: var(--primary-active);
}

.btn-secondary {
    --btn-back: var(--secondary);
    --btn-back-active: var(--secondary-active);
}

.btn-tertiary {
    --btn-back: var(--tertiary);
    --btn-back-active: var(--tertiary-active);
}

.btn.btn-default {
    --btn-back: var(--grey-500);
    --btn-back-active: var(--grey-400);
}

.btn.btn-danger {
    --btn-back: var(--red-600);
    --btn-back-active: var(--red-700);
}

.btn.btn-success {
    --btn-back: var(--green-700);
    --btn-back-active: var(--green-800);
}

.form-control-btn {
    position: absolute;
    background: none;
    border: none;
    font-size: 1.5em;
    top: .65em;
    right: .5em;
    color: var(--field-color);
    transition: color .25s ease;
}

.form-control-btn:hover,
.form-control-btn:focus {
    color: var(--secondary-bg-500);
}
/*--------------------------------------------*/

.clearer {
    clear: both;
    height: 0px;
    overflow: hidden;
    font-size: 0px;
    line-height: 0px;
}

.clear:after {
    content: " ";
    clear: both;
    display: block;
}

#page hr {
    height: 5px;
    overflow: hidden;
    color: var(--secondary);
    border: none;
    width: 100px;
    background-color: var(--secondary);
}

.popover {
    min-width: 300px;
}

/*--------------------------------------------*/

.spacing {
    margin-top: 15px;
    margin-bottom: 15px;
}

.spacing_top {
    margin-top: 15px;
}

.spacing_bottom {
    margin-bottom: 15px;
}

.padding {
    padding-left: 15px;
    padding-right: 15px;
}

.padding_left {
    padding-left: 15px;
}

.padding_right {
    padding-right: 15px;
}

.padding_top {
    padding-top: 15px;
}

.padding_bottom {
    padding-bottom: 15px;
}

.nopadding {
    padding: 0px;
}

.nopadding_right {
    padding-right: 0px;
}

.nopadding_left {
    padding-left: 0px;
}

/*--------------------------------------------*/

.push_right {
    float: right;
}

.push_left {
    float: left;
}

/*--------------------------------------------*/

img.alignright {
    float: right;
    margin-left: 20px;
    margin-bottom: 4px;
    display: block;
}

img.aligncenter {
    text-align: center;
    margin: 1em auto 5px auto;
    clear: both;
    display: block;
}

img.alignleft {
    float: left;
    margin-right: 20px;
    margin-bottom: 4px;
    display: block;
}

img.fullwidth {
    margin: 0px;
    display: block;
}

img.drop_shadow {
    border: 1px solid #AAAAAA;
    -webkit-box-shadow: 5px 5px 5px #AAAAAA;
    -moz-box-shadow: 5px 5px 5px #AAAAAA;
    box-shadow: 5px 5px 5px #AAAAAA;
}

/*--------------------------------------------*/

.section {
    padding-bottom: 50px;
    padding-top: 50px;
}

.section header {
    margin-bottom: 25px;
}

/*--------------------------------------------*/

[data-twttr-id] .twitterborderhide {
    position: relative;
    top: -6px;
    border-top: 1px solid #fff;
}

/*-----------------------------------------------------------------------------------------------*/

html {
    font-size: 16px;
}

body {
    margin: 0px;
    color: #000000;
    font-weight: normal;
    font-size: 1rem;
    line-height: 1.5em;
    font-family: 'Open Sans', Helvetica, Arial, Sans-Serif;
}

body > form {
    margin: 0px;
}

.blur {
    -webkit-filter: blur(7px);
    -moz-filter: blur(7px);
    filter: blur(7px);
}

.page_inset {
    padding: 30px;
    background-color: #FFFFFF;
    border: 1px solid rgba(156, 175, 176, 0.8);
}

/*-----------------------------------------------------------------------------------------------*/

.alert-bar {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    width: 100%;
    background: var(--tertiary);
    color: #fff;
    padding: .75em;
    text-align: center;
    gap: 1.5em;
}

.alert-bar a {
    color: #fff;
    font-weight: bold;
}

.alert-bar .btn + .btn {
    margin-left: 5px;
}

/*-----------------------------------------------------------------------------------------------*/

#back-to-top {
    position: fixed;
    bottom: 40px;
    right: 40px;
    z-index: 9999;
    transition: opacity 0.2s ease-out, background .25s ease;
    opacity: 0;
    width: 2.5em;
    height: 2.5em;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1;
}

#back-to-top .fa {
    margin-bottom: 2px;
}

#back-to-top.in {
    opacity: 1;
}

/*-----------------------------------------------------------------------------------------------*/

.header-wrap {
    position: relative;
    z-index: 11;
    filter: drop-shadow(0 25px 4px rgba(0,0,0,.3));
}

.header-wrap .header-back {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #fff;
    background-image: url(../../images/pattern.png);
    background-repeat: no-repeat;
    background-size: 100% 140%;
    background-position: center bottom;
}

@supports (clip-path: url('')) {
    .header-wrap .header-back {
        clip-path: url('#header-clip-path');
    }
}

#header-clip-paths {
    height: 0;
    width: 0;
    position: fixed;
    top: 0;
}

#header {
    padding-top: 30px;
    padding-bottom: 80px;
    position: relative;
    overflow: hidden;
}

#header .container {
    position: static;
}

#header .header-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

#header .header-right {
    margin-bottom: 10px;
}

#header .logo {
    margin: 0 0 -30px;
    z-index: 99;
}

#header .logo img {
    height: 12em;
}

#header .header-description {
    margin-bottom: 30px;
    text-align: right;
    font-size: 1.5rem;
    line-height: 1.2em;
}

#header .header-actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 15px;
}

#header .header-actions .header-buttons {
    position: relative;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 15px;
}

#header a:not([class]) {
    color: var(--tertiary);
}

#header a:not([class]):hover {
    color: var(--secondary);
}

/*-----------------------------------------------------------------------------------------------*/

#page {
    margin-top: -90px;
}

#content {
    margin-top: 30px;
}

/*-----------------------------------------------------------------------------------------------*/

.intro-section {
    position: relative;
    padding: 0 0 30px;
    margin: -30px 0 0;
}

.intro-section h1,
.intro-section h2,
.intro-section h3,
.intro-section h4 {
    color: #000;
}

.intro-section .home-pills {
    position: relative;
    display: flex;
    gap: 15px;
    padding: 0 0 15px;
    margin: -55px 0 0;
    z-index: 9;
}

.intro-section .home-pills > .home-pill-col {
    flex: 1;
}

.intro-section .home-pills > .home-pill-col:first-of-type {
    text-align: right;
}

.intro-section .home-pill-link {
    position: relative;
    padding: 15px 30px 15px 145px;
    color: #fff;
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    background-repeat: no-repeat;
    background-position: left 45px center;
    background-size: 80px;
    min-width: 90%;
    min-height: 110px;
    font-size: 1.2rem;
    text-align: center;
    border-top-left-radius: 10% 50%;
    border-bottom-left-radius: 10% 50%;
    border-top-right-radius: 10% 50%;
    border-bottom-right-radius: 10% 50%;
    transition: background-color 0.3s linear, color 0.3s linear;
}

.intro-section .home-pill-link:focus,
.intro-section .home-pill-link:hover {
    color: #fff;
}

.intro-section .home-pill-link.professionals {
    background-color: var(--secondary);
    background-image: url(../../images/professionals.png);
}

.intro-section .home-pill-link.professionals:focus,
.intro-section .home-pill-link.professionals:hover {
    background-color: var(--secondary-active);
}

.intro-section .home-pill-link.patients {
    background-color: var(--primary);
    background-image: url(../../images/patients.png);
}

.intro-section .home-pill-link.patients:focus,
.intro-section .home-pill-link.patients:hover {
    background-color: var(--primary-active);
}

    .intro-section .home-pill-link.resources {
        background-color: var(--tertiary);
        background-image: url(../../images/patients.png);
    }

        .intro-section .home-pill-link.resources:focus,
        .intro-section .home-pill-link.resources:hover {
            background-color: var(--tertiary-active);
        }


.intro-section .home-pill-link strong {
    display: block;
    font-weight: 400;
    font-size: 2rem;
    line-height: 1.2em;
}

.intro-section .home-blocks {
    padding: 15px 0 0;
}

.intro-section .home-block-area {
    position: relative;
    min-height: 230px;
    font-size: 1.2rem;
    line-height: 1.2em;
    color: #fff;
    text-transform: uppercase;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    background-color: rgba(var(--tertiary-rgb), 0.25);
}

.intro-section .home-block-area > a {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 9;
}

.intro-section .home-block-area::before {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    transition: background 0.3s linear;
}

.intro-section .home-block-area:focus::before,
.intro-section .home-block-area:hover::before {
    background: rgba(var(--tertiary-rgb), 0.5);
    backdrop-filter: blur(5px);
}

.intro-section .home-block-area .home-block-area-link {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    width: calc(100% - 30px);
    text-align: center;
    background: var(--tertiary);
    padding: 8px 15px;
    margin: 0 15px;
    border-radius: 15px;
    z-index: 9;
    transition: background 0.3s linear;
}

.intro-section .home-block-area:focus .home-block-area-link,
.intro-section .home-block-area:hover .home-block-area-link {
    background: transparent;
}

.intro-section .home-block-area .home-block-area-link a {
    color: #fff;
}

.social-section {
    position: relative;
    padding: 45px 0;
    text-align: center;
}

.social-section h2 {
    font-size: 2rem;
    line-height: 1.2em;
    color: var(--tertiary);
    margin: 0 0 30px;
}

.about-section {
    position: relative;
    padding: 45px 0;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    color: #fff;
}

.about-section .image_upload {
    width: 100% !important;
    margin: 0 0 15px;
}

.about-section::before {
    position: absolute;
    content: "";
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: rgba(var(--secondary-rgb), 0.8);
}

.about-section .container {
    position: relative;
}

.about-section hr {
    color: #fff !important;
    background-color: #fff !important;
}

.about-section h2 {
    font-size: 2em;
    line-height: 1.15em;
    color: #fff;
}

.about-section h3 {
    font-size: 3.8rem;
    line-height: 1.2em;
    color: var(--quaternary);
}

.about-section h3 > span {
    display: block;
    color: #fff;
}

.about-section h3 > span span {
    font-size: 2em;
    line-height: 1.2em;
}

#content .about-section ul:not([class]):not([id]) li::marker {
    color: #fff;
}

#content .about-section ul.tick-list li::before {
    background-image: url(../../images/tick_w.png);
}

.partners-section {
    position: relative;
    padding: 45px 0 15px;
    text-align: center;
}

.partners-section h2 {
    font-size: 2rem;
    line-height: 1.2em;
    color: var(--tertiary);
    margin: 0 0 30px;
}

/*-----------------------------------------------------------------------------------------------*/

.lower_banner {
    position: relative;
    left: 0;
    height: 250px;
    overflow: hidden;
    background-color: rgba(var(--tertiary-rgb), 0.25);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.lower_banner .container {
    position: relative;
    height: 100%;
}

.lower_banner .container h1,
.lower_banner .container p,
.lower_banner .container span {
    position: absolute;
    display: block;
    margin: 0px;
    padding: 0;
    left: 15px;
    bottom: 15px;
    max-width: 90%;
    color: var(--tertiary);
    font-size: 2.5rem;
    line-height: 1.2em;
}

.lower_banner .image_upload_instructions {
    margin-top: 100px;
    z-index: 99;
}

/*-----------------------------------------------------------------------------------------------*/

.breadcrumb {
    padding: 0px;
    background-color: transparent;
}

.breadcrumb > li + li:before {
    color: #000000;
}

.breadcrumb > .active {
    color: #000000;
}

/*-----------------------------------------------------------------------------------------------*/

.expandable {
    clear: both;
    margin-bottom: 15px;
}

.expandable_heading .expandable_title {
    margin: 0px;
    color: #FFFFFF !important;
    text-align: center;
}

.expandable_heading .expandable_title a {
    display: block;
    padding: 10px;
    color: #FFFFFF !important;
    text-decoration: none;
}

.expandable_heading .expandable_title a.collapsed {
    background: none;
}

.expandable_heading .expandable_title a,
.expandable_heading .expandable_title a.collapsed:hover {
    background: rgba(0, 0, 0, 0.2);
}

.expandable_heading .expandable_title .glyphicon {
    float: right;
    transition: transform 0.5s;
    transform: rotate(180deg);
    font-size: .8em;
}

.expandable_heading .expandable_title .collapsed .glyphicon {
    transform: rotate(0deg);
}

.expandable_collapse {
    overflow: hidden;
}

.expandable_body {
    padding: 15px;
    font-size: 0.9em;
}

.expandable_body h3.media-heading a {
    color: #000000;
}

/*--------------------------------------------*/

.editable_expandable {
    clear: both;
    margin: 15px 0px;
}

.editable_expandable .expandable_heading,
.editable_expandable .expandable_heading .expandable_title,
.editable_expandable .expandable_heading .expandable_title a {
    background: var(--tertiary) !important;
    color: #fff !important;
}

.editable_expandable .expandable_heading h4 {
    margin: 0px;
}

.editable_expandable .expandable_title {
    text-align: left;
}

.editable_expandable .expandable_body {
    border: 2px solid var(--tertiary);
    border-top: none;
}

.editable_expandable .expandable_body > :first-child {
    margin-top: 0px;
}

/*-----------------------------------------------------------------------------------------------*/

#footer {
    margin: 30px 0 0;
    padding: 30px 0;
    color: #FFFFFF;
    background-color: var(--tertiary);
}

#footer .footer-container {
    display: flex;
    align-items: center;
    gap: 15px;
}

#footer .footer-container + .footer-container {
    padding: 15px 0 0;
}

#footer .footer-container > .footer-container-col {
    flex: 1;
}

#footer .footer-item + .footer-item {
    margin: 0 0 0 20px;
}

#footer .footer-logo {
    width: 18em;
}

#footer .footer-options {
    text-align: right;
}

    #footer .footer-socials {
        padding: 15px 0 0;
        text-align: right;
        margin-bottom: 60px;
    }

#footer .footer-social {
    display: inline-block;
    line-height: 1rem;
}

#footer .footer-social + .footer-social {
    margin: 0 0 0 5px;
}

#footer .footer-social svg {
    fill: #FFFFFF;
    transition: fill 0.3s linear;
    width: 2em;
    height: 2em;
}

#footer .footer-social:hover svg {
    fill: var(--secondary);
}

#footer hr {
    color: #fff;
    background-color: #fff;
    margin: 15px 0 15px 25%;
}

#footer a {
    color: #FFFFFF;
}

#footer a:hover {
    color: var(--secondary);
}

circle:hover {
    fill: var(--secondary);
}

/*#region Alerts*/
.alert {
    border: none;
    border-left: 5px solid transparent;
    border-radius: 5px;
    text-shadow: none;
    box-shadow: none;
    -webkit-box-shadow: none;
    color: #333 !important;
}

.alert-dismissable .close {
    color: #000 !important;
    text-shadow: none;
    opacity: .5;
    transition: opacity .25s ease;
}

.alert-dismissable .close:hover,
.alert-dismissable .close:focus {
    opacity: 1;
}

.alert-success {
    background: #d3f3c6;
    border-color: #4CAF50;
}

.alert-info {
    background: var(--lightblue-100);
    border-color: var(--lightblue-300);
}

.alert-warning {
    background: #f7edb6;
    border-color: #FDD835;
}

.alert-danger {
    background: #f3bfbf;
    border-color: #EF5350;
}

.alert-default {
    background: var(--grey-200);
    border-color: var(--grey-350);
}

.alert ul li::marker {
    color: #333 !important;
}
/*#endregion*/

/*#region Panels*/
.panel {
    box-shadow: none;
    border: 2px solid var(--panel-border);
    border-radius: var(--radius);
}

.panel .panel-heading {
    background: var(--panel-back);
    border-bottom: 2px solid var(--panel-border);
    border-top-left-radius: var(--radius);
    border-top-right-radius: var(--radius);
}

.panel.panel-default {
    --panel-border: var(--grey-350);
    --panel-back: var(--grey-200);
}
/*#endregion*/

/*#region Listings*/
.listing-container {
    display: flex;
    flex-wrap: wrap;
    gap: 1em;
}

.listing-title {
    background: var(--primary);
    color: #fff;
    padding: .5em 1em;
    margin-left: -.5em;
    margin-bottom: -1rem;
    position: relative;
    z-index: 1;
    display: inline-block;
}

.listing {
    --width: 50%;
    flex-grow: 1;
    flex-basis: calc(var(--width) - 1em);
    max-width: calc(var(--width) - 1em);
    min-width: 20em;
    border-radius: var(--radius);
}

.listing > :first-child {
    border-top-left-radius: var(--radius);
    border-top-right-radius: var(--radius);
}

.listing > :last-child {
    border-bottom-left-radius: var(--radius);
    border-bottom-right-radius: var(--radius);
}

.listing.inline {
    flex-basis: 100%;
    min-width: 0;
    max-width: none;
}

.listing-title + .listing-container .listing:first-child > a h3:first-child {
    margin-top: 1rem;
}

.listing.solid {
    --listing-color: var(--grey-250);
    background: var(--listing-color);
    transition: background .25s ease;
    padding: 1.5em;
}

.listing.solid:hover {
    --listing-color: var(--grey-300);
}

.listing img,
.listing .img {
    height: 15em;
    width: 100%;
    object-fit: cover;
    position: relative;
}

.listing .img {
    background: var(--quaternary);
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--tertiary);
    transition: background .25s ease;
}

.listing:hover .img {
    background: var(--quaternary-active);
}

.listing .img > .fa {
    font-size: 5em;
}

.listing h3 {
    margin-bottom: 0;
    font-weight: 500;
    font-size: 1.75em;
}

.listing a h3 {
    transition: color .25s ease;
}

.listing a:hover h3,
.listing a:focus h3 {
    color: var(--secondary);
}

.listing time {
    display: block;
    color: var(--primary);
    font-size: 1.5em;
    font-weight: 300;
}

.listing-actions {
    display: flex;
    justify-content: flex-end;
    gap: 1em;
}

.listing-container + .listing-actions {
    margin-top: 1em;
}

/*#region Listing Options*/
.listing-options {
    margin: 1em 0;
    padding: 1em;
    background: var(--grey-100);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 1em;
}

.listing-options:first-child {
    margin-top: 0;
}

.listing-options .listing-filters {
    display: flex;
    flex-wrap: wrap;
}

.listing-options .listing-filters .btn-group {
    width: 12.5em;
    margin-right: .5em;
}

.listing-options .listing-filters .form-group {
    margin-bottom: 0;
}

.listing-options .listing-views {
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: .5em;
}

.listing-options .listing-views .pagination {
    margin: 0;
}

.listing-options .listing-search {
    display: flex;
    flex-wrap: wrap;
    gap: .5em;
    align-items: center;
    flex-grow: 1;
}

.listing-options .listing-search .form-group {
    flex-grow: 1;
    margin: 0;
}
/*#endregion*/

/*#region Listing Categories*/
ul.listing-categories {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    padding-left: 0;
    gap: 1em;
}

ul.listing-categories li.listing-category.parent {
    flex-basis: calc(25% - 1em);
    min-width: 15em;
    max-width: 100%;
}

ul.listing-categories li.listing-category.parent > div > label {
    color: var(--primary-500);
    font-weight: 500;
    margin-bottom: .5em;
    display: inline-block;
}

ul.listing-categories li.listing-category.parent ul {
    padding-left: 1em;
}

ul.listing-categories input[type=checkbox].toggle-all + label {
    margin-left: .25em;
}

.chips {
    display: flex;
    flex-wrap: wrap;
    gap: .5em;
}

ul.chips {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

.chip {
    font-size: .8em;
    margin-left: .25em;
    margin-bottom: 0;
    padding: .45em 1.25em;
    border-radius: 2em/100%;
    background: var(--primary-500);
    white-space: nowrap;
    color: #fff;
    font-weight: normal
}

.chip.secondary {
    background: var(--secondary);
}

.chip.accent {
    background: var(--primary);
}

.chip.large {
    font-size: 1em;
    font-weight: 600;
}

.chips .chip {
    margin-left: 0;
    line-height: 1;
}

.listing .img .chips {
    position: absolute;
    left: 1em;
    bottom: 1em;
    margin: 0;
    font-size: .9em;
}
/*#endregion*/

/*#endregion*/