html {
    overflow-x:hidden
}

@font-face {
    font-family: 'Futura PT Demi';
    src: url('/styles/fonts/FuturaPTDemi/font.woff') format('woff');
    font-weight: 600; /* or as appropriate for 'Demi' */
    font-style: normal;
}

body {
    font-family: Proxima Nova, sans-serif;
    overflow-x: hidden;
    word-wrap: break-word;
    font-size: 1em;
    letter-spacing: 0;
    line-height: 1.5;
    color: rgba(0, 0, 0, .8);
    visibility:hidden
}

hr {
    max-width: 700px;
    margin:auto;
    display:none;
}

a:focus {
    opacity:.8
}

footer {
    background: #fff;
    color: #fff;
    position: relative;
    bottom: 0;
    width:100%
}

.bg-pattern {
    background:url("/images/blackbg.png") repeat !important;
}

.homepage-footer {
    background:rgba(0, 0, 0, 0)
}

.footer-logo {
    width: 30px !important;
    height: 30px !important;
    margin:5px 5px 5px 0
}

.media-img:hover {
    opacity:.8
}

footer a:hover {
    text-decoration: underline !important;
    cursor:pointer
}

.list-group .list-group-item:first-of-type {
    cursor: default;
    text-decoration:none !important
}

.logobox a:hover {
    text-decoration:none !important
}

.list-group-item {
    border: none;
    padding-bottom: 0;
    background-color: inherit;
    color:#fff
}

.list-group > .list-group-item {
    font-size: 14px;
    font-weight:500
}

.list-group > .list-group-item:first-of-type {
    font-weight: 700;
    font-size:16px
}

footer .col-6 > div {
    margin-top:25px
}

footer .col-6 > div:first-of-type {
    margin-top:50px
}

footer .col-6 > div:last-of-type {
    margin-bottom:50px
}

footer span {
    font-size: 12px;
    font-weight: 700;
    letter-spacing:2px
}

a {
    text-decoration: none !important;
    color: inherit !important;
    cursor:pointer
}

.indexa a {
    color: #6356cb !important;
    text-decoration:none !important
}

.indexa a:hover {
    color: #4f45a3 !important;
    text-decoration:underline !important
}

.indexb a {
    text-decoration:none !important
}

.indexb a:hover {
    text-decoration:underline !important
}

h5 a {
    color: #9c96cd !important;
    text-decoration:none !important
}

h5 a:hover {
    color: #aaa5db !important;
    text-decoration:underline !important
}

.homepage-link {
    color: #867eba !important;
    text-decoration: underline !important;
    font-weight:700
}

.homepage-link:hover {
    color: #aaa5db !important;
    text-decoration: underline !important;
    text-shadow:0 0 1px #aaa5db
}

.btn-primary {
    color: #847eb9 !important;
    background-color: #fff !important;
    border-color: #847eb9 !important;
    font-weight: 700;
    max-height:50px
}

.btn-primary:hover {
    color: #fff !important;
    background: #aaa5db !important;
    border-color: #847eb9 !important;
    box-shadow:0 0 0 4px #aaa3e134
}

.btn-outline-primary {
    color: #918bbb !important;
    border-color: #918bbb !important;
    font-weight:700
}

.btn-outline-primary:hover {
    color: #fff !important;
    background: #aaa5db !important;
    border-color: #aaa5db !important;
    box-shadow:0 0 0 4px #aaa3e134
}

p > a {
    font-weight:500
}

.col-feature > h4 {
    font-weight:900
}

.landing {
    height: calc(75vh - 63px);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    max-width:100vw
}

.matching-banner {
    min-height: calc(25vh);
    width: 100%;
    margin-top: 0;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    align-items: center;
    background: #f7deff;
    background: radial-gradient(circle, #f7deff 0, #dee2ff 75%);
    padding:5px
}

.homepage {
    z-index: -1;
    opacity: .7;
    width: 30vh;
    max-width: 45vw;
    position:absolute
}

.homepage2 {
    z-index: -2;
    width: 60vh;
    position: absolute;
    opacity: .3;
    max-width:90vw
}

.intro-text {
    text-shadow: 0 0 20px #fff;
    font-family: Futura PT Demi, sans-serif;
    max-width:90%
}

.four-panel {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    background: #fff;
    height: 180px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-radius:5px
}

.four-panel img {
    cursor: pointer;
    max-height: 100%;
    max-width: 100%;
    -o-object-fit: contain;
    object-fit:contain
}

.post {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    border-bottom: 1px solid silver;
    padding-top: 12px;
    padding-bottom:12px
}

.row > .post:last-of-type {
    border-bottom:none
}

.post p {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    text-align:right
}

.post-title {
    -ms-flex-item-align: center;
    -ms-grid-row-align: center;
    align-self:center
}

.description {
    -ms-flex-item-align: center;
    -ms-grid-row-align: center;
    align-self:center
}

.date {
    padding: 0;
    margin: 0;
    white-space: nowrap;
    -ms-flex-item-align: center;
    -ms-grid-row-align: center;
    align-self: center;
    font-size:.9em
}

.social-media {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-box-orient: horizontal !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: row !important;
    flex-direction:row !important
}

.social-media img {
    max-width: 22px !important;
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    margin-right: 10px !important;
    border-radius: 3px !important;
    width:auto !important
}

.video {
    border-radius: 10px;
    overflow:hidden
}

.video-img:hover {
    opacity:.7
}

.cookie-consent {
    position: fixed;
    bottom: 8px;
    left: 20px;
    width: 260px;
    padding-top: 7px;
    height: 83px;
    color: #fff;
    line-height: 20px;
    padding-left: 10px;
    padding-right: 10px;
    font-size: 14px;
    background: #292929;
    z-index: 120;
    cursor: pointer;
    border-radius:3px
}

.allow-button {
    height: 20px;
    width: 104px;
    color: #fff;
    font-size: 12px;
    line-height: 10px;
    line-height: 10px;
    border-radius: 3px;
    border: 1px solid green;
    background-color:green
}

.accordion {
    background-color: rgba(0, 0, 0, 0);
    color: #000;
    cursor: pointer;
    padding: 10px 18px 8px 0;
    text-align: left;
    border: none;
    outline: 0;
    font-size: 1em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%;
    font-weight:700
}

.bg-dark {
    background:#212529 !important
}

.panel {
    padding: 0 8px;
    background-color: #fff;
    max-height: 0;
    margin-right: auto;
    overflow: hidden;
    -webkit-transition: max-height .2s ease-out;
    -o-transition: max-height .2s ease-out;
    transition: max-height .2s ease-out;
    background-color:rgba(0, 0, 0, 0)
}

.accordion:after {
    content: '\02795';
    font-size: 8px;
    color: #fff;
    margin-right:-10px
}

.panel p {
    margin-bottom: 6px;
    width:98%
}

#team {
    background:#eee !important
}

section {
    padding:60px 0
}

section .section-title {
    text-align: center;
    color: #007b5e;
    margin-bottom: 50px;
    text-transform:uppercase
}

.image-flip.hover .backside, .image-flip:hover .backside {
    -webkit-transform: rotateY(0);
    -ms-transform: rotateY(0);
    transform: rotateY(0);
    border-radius:.25rem
}

.image-flip.hover .frontside, .image-flip:hover .frontside {
    -webkit-transform: rotateY(180deg);
    transform:rotateY(180deg)
}

.mainflip {
    -webkit-transition: 1s;
    -webkit-transform-style: preserve-3d;
    -ms-transition: 1s;
    -moz-transition: 1s;
    -moz-transform: perspective(1000px);
    -moz-transform-style: preserve-3d;
    -ms-transform-style: preserve-3d;
    -o-transition: 1s;
    transition: 1s;
    transform-style: preserve-3d;
    position:relative
}

.frontside {
    position: relative;
    -webkit-transform: rotateY(0);
    -ms-transform: rotateY(0);
    z-index: 2;
    margin-bottom:30px
}

.backside {
    position: absolute;
    top: 0;
    left: 0;
    background: #fff;
    -webkit-transform: rotateY(-180deg);
    -ms-transform: rotateY(-180deg);
    transform: rotateY(-180deg);
    -webkit-box-shadow: 5px 7px 9px -4px #9e9e9e;
    box-shadow:5px 7px 9px -4px #9e9e9e
}

.backside, .frontside {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    -webkit-transition: 1s;
    -webkit-transform-style: preserve-3d;
    -moz-transition: 1s;
    -moz-transform-style: preserve-3d;
    -o-transition: 1s;
    -o-transform-style: preserve-3d;
    -ms-transition: 1s;
    -ms-transform-style: preserve-3d;
    transition: 1s;
    transform-style:preserve-3d
}

.emailbox {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    margin:10px 0 10px 0
}

.emailbox label {
    font-weight: 700;
    font-size:1em
}

.emailinput {
    background: 0 0;
    border: none;
    border-bottom: solid 1px grey;
    width: 192px;
    margin-right: 5px;
    color:#fff !important
}

.emailinput:focus {
    border:none
}

.emailsubmit {
    border: 1px solid #918bbb;
    height: 28px;
    font-size: 12.8px;
    padding: 0 6px 0 6px !important;
    border: none !important;
    border-radius: 5px;
    color: #918bbb !important;
    font-weight: 700;
    background:#fff !important
}

.emailsubmit:hover {
    background: #aaa5db !important;
    color:#fff !important
}

.footer-top {
    width: 33%;
    max-width:33%
}

.footer-bottom {
    width: 66%;
    max-width: 66%;
    margin-left: auto;
    margin-bottom:25px
}

@media screen and (max-width: 992px) {
    .footer-top {
        min-width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: distribute;
        justify-content: space-around;
        -webkit-box-align: baseline;
        -ms-flex-align: baseline;
        align-items:baseline
    }

    .footer-bottom {
        min-width: 100%;
        text-align:center
    }
}

@media screen and (max-width: 720px) {
    .footer-top {
        min-width: 100%;
        display:block
    }

    .footer-bottom {
        text-align: left;
        padding: 0;
        min-width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -ms-flex-pack: distribute;
        justify-content: space-around;
        -webkit-box-align: baseline;
        -ms-flex-align: baseline;
        align-items: baseline;
        padding:0
    }

    .footer-bottom .list-group {
        display: -webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        margin: 10px 0 10px 0 !important;
        padding:0 !important
    }

    .footer-bottom .list-group > .list-group-item:first-of-type {
        display: block !important;
        width: 100%;
        margin-top:0
    }

    .list-group .list-group-item {
        padding-left:0
    }
}

.citation-appendix, d-appendix {
    color:rgba(0, 0, 0, .7) !important
}

d-appendix a, d-article a {
    color: #6356cb !important;
    border-bottom:#6356cb 1px solid !important
}

.anchorjs-link {
    border-bottom:none !important
}

d-appendix a:hover, d-article a:hover {
    color:#4f45a3 !important
}

.donate-crypto-icon {
    width: 30px !important;
    padding:0 auto 0 auto !important
}

footer a:hover, nav a:hover {
    border:none
}

d-article a, d-article a:hover {
    border:none
}

.d-contents nav a:hover {
    text-decoration:underline !important
}

@media all and (max-width: 1000px) {
    .d-contents {
        border-bottom:solid 1px rgba(0, 0, 0, .1)
    }
}

.csl-entry > span {
    font-weight:700 !important
}

.email {
    cursor: pointer;
    word-wrap:break-word
}

.tags {
    display: inline-block;
    cursor:pointer
}

.subtext {
    font-size: .7em;
    font-style:italic
}

#mc-embedded-subscribe {
    color: #fff;
    border: 1px solid #fff;
    background: #303035;
    padding: 5px;
    margin:auto
}

.body-text {
    z-index: 1;
    margin: auto;
    font-size: 1em;
    line-height: 1.5;
    letter-spacing: 0;
    max-width:800px
}

.body-text a {
    color: #6356cb !important;
    text-decoration:none !important
}

.link a:hover {
    color: #4f45a3 !important;
    text-decoration:underline !important
}

.link a {
    color: #6356cb !important;
    text-decoration:none !important
}

.body-text a:hover {
    color: #4f45a3 !important;
    text-decoration:underline !important
}

.body-text h2, .body-text h3 {
    margin-top: 20px;
    margin-bottom:20px
}

.body-text img {
    display: block;
    margin: 25px auto 25px auto;
    border-radius: 5px;
    max-width: 100%;
    -o-object-fit: cover;
    object-fit:cover
}

@media all and (max-width: 992px) {
    .email {
        width:150px
    }
}

.img-fluid {
    max-width: 100% !important;
    height:auto !important
}

@media only screen and (min-width: 1000px) {
    .l-middle {
        width: 120%;
        margin-left:-10%
    }
}

@media only screen and (min-width: 1000px) {
    .l-page {
        width: 120%;
        margin-left:-10%
    }
}

.side-by-side-2 > figure {
    max-width:45%
}

.side-by-side-2 {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items:center
}

@media only screen and (max-width: 1000px) {
    .side-by-side-2 {
        text-align: center;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: distribute;
        justify-content: space-around;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items:center
    }

    .side-by-side-2 > figure {
        max-width:80%
    }
}

.side-by-side-3 > figure {
    max-width:30%
}

.side-by-side-3 {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
    justify-content: space-around;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items:flex-end
}

@media only screen and (max-width: 1000px) {
    .side-by-side-3 {
        text-align: center;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: distribute;
        justify-content: space-around;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items:center
    }

    .side-by-side-3 > figure {
        max-width:80%
    }
}

.do-not-column {
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction:row
}

.post2 img {
    border-radius: 5px;
    -o-object-fit: contain;
    object-fit: contain;
    background: #fff;
    cursor: pointer;
    width: 100%;
    height:auto
}

.side-by-side-4 {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
    justify-content:space-around
}

.side-by-side-4 > figure {
    max-width:22.5%
}

.side-by-side-5 {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: distribute;
    justify-content:space-around
}

.side-by-side-5 > figure {
    max-width:18%
}

figure {
    text-align:center !important
}

.figure {
    display: inherit !important;
    text-align:center !important
}

figcaption {
    margin:10px 0 10px 0
}

.shamil-boa {
    margin-top:-28px
}

@media only screen and (max-width: 1000px) {
    .shamil-boa {
        margin-top:0
    }
}

.citation {
    margin-left: 3px !important;
    margin-right: 0 !important;
    font-size: .8em !important;
    cursor:default !important
}



html {
    font-size:16px !important
}

.emailbanner {
    display: none;
    text-align: center;
    font-weight: 700;
    font-size: .8em;
    font-family: Futura PT Demi, sans-serif;
    background: #0051ff !important;
    color: #fff;
    z-index: 10000;
    position: absolute;
    width:100%
}

.emailbanner > span {
    margin: auto !important;
    display: block;
    padding: 6px 0 6px 0;
    letter-spacing:2px
}

.emailbanner > span > a {
    text-decoration:underline !important
}

.closeemailbanner {
    display: inline-block;
    float: right;
    cursor: pointer;
    margin-right: 12px;
    margin-left:-32px
}

.skip-link {
    position: absolute;
    top: -40px;
    left: 0;
    background: #000;
    color: #fff;
    padding: 8px;
    z-index:100
}

.skip-link:focus {
    top:0
}

.cookiebanner {
    background: -o-linear-gradient(36deg, rgba(246, 199, 231, .2) 0, rgba(205, 210, 236, .2) 67%, rgba(255, 234, 226, .2) 100%) !important;
    background: linear-gradient(54deg, rgba(246, 199, 231, .2) 0, rgba(205, 210, 236, .2) 67%, rgba(255, 234, 226, .2) 100%) !important;
    margin: 16px 0 16px 0;
    padding: 6px 0 6px 0;
    display: none;
    text-align: center;
    font-size: .8em;
    font-weight: 700;
    font-family:Futura-PT-Demi, sans-serif;
}

.cookiebanner > a {
    text-decoration:underline !important
}

.closecookiebanner {
    display: inline-block;
    float: right;
    cursor: pointer;
    margin-right: 16px;
    margin-left:-32px
}

a:visited {
    color:none !important
}

a:focus {
    color:none !important
}

.recent-posts {
    -webkit-transform: translateZ(0);
    transform:translateZ(0)
}

.video {
    border:none !important
}

.donate-crypto-icon {
    width: 30px !important;
    padding:0 auto 0 auto !important
}

.blog a, .people a {
    color:#000 !important
}

.blog a:active, .blog a:hover, .people a:active, .people a:hover {
    color: #000 !important;
    opacity: .6 !important;
    text-decoration:none !important
}

.blog-type {
    font-size: 12px;
    margin-top: 2px;
    text-transform: uppercase;
    color: #212529;
    display:block
}

.white {
    color:#fff !important
}

.rss-icon {
    display: inline-block;
    width: 20px;
    margin-left: 10px;
    margin-top:-10px
}

hr {
    max-height: 1px;
    background-color: #000;
    border:0 none
}

.tag {
    font-size:40px !important
}

@media only screen and (min-width: 768px) {
    .hero-image-container {
        margin-right:0 !important
    }
}

.hero-text {
    font-family: Futura PT Demi, sans-serif !important;
    margin-bottom: 0 !important;
    padding-bottom:0 !important
}

.donation-button {
    background: #fff !important;
    border-radius: 5px;
    padding: 4px 6px 4px 6px !important;
    margin: 4px -6px 4px -6px !important;
    color: #918bbb !important;
    border: 1px solid #918bbb !important;
    font-weight:700
}

.donation-button:hover {
    background: #aaa5db !important;
    border-radius: 5px;
    padding: 4px 6px 4px 6px !important;
    margin: 4px -6px 4px -6px !important;
    color:#fff !important
}

.donation-footer-link {
    background: #fff !important;
    border-radius: 5px;
    border: 1px solid #918bbb !important;
    color: #918bbb;
    padding: 4px 6px 4px 6px !important;
    display:inline-block
}

.donation-footer-link:hover {
    background: #aaa5db !important;
    border-radius: 5px;
    padding: 4px 6px 4px 6px !important;
    color:#fff
}

@media screen and (max-width: 460px) {
    .donation-footer-link {
        margin-top:-4px !important
    }
}

.content-width {
    width: 100%;
    max-width: 1400px;
    margin:auto !important
}

.content-head-background {
    background: -o-linear-gradient(36deg, rgba(246, 199, 231, .6) 0, rgba(205, 210, 236, .6) 67%, rgba(255, 234, 226, .6) 100%);
    background:linear-gradient(54deg, rgba(246, 199, 231, .6) 0, rgba(205, 210, 236, .6) 67%, rgba(255, 234, 226, .6) 100%)
}

.toc a {
    color: rgba(0, 0, 0, .6) !important;
    border-bottom: none !important;
    text-decoration:underline !important
}

.toc a:hover {
    color: rgba(0, 0, 0, .9) !important;
    border-bottom:none !important
}

.progress2 {
    border:#000 solid 1px
}

.progress-bar2 {
    height: 8px;
    background-image: linear-gradient(to bottom, rgba(255, 255, 255, .3), rgba(255, 255, 255, .05));
    transition: .4s linear;
    transition-delay: .2s;
    transition-property:width, background-color
}

.progress-moved .progress-bar2 {
    width: 100%;
    background-color: #766adf;
    animation:progressAnimation 6s
}

@keyframes progressAnimation {
    0% {
        width:0%
    }

    100% {
        width:100%
    }
}

.container {
    max-width:1200px;
}


      .news-quote-text {
        max-width:600px;
        margin: 0 auto;
  font-size: 1.6rem; /* Larger text for impact */
  line-height: 1.8; /* Spacing between lines */
  color: #333; /* Dark text color for contrast */
  font-style: italic; /* Italic style for the quote */
  margin-bottom: 1.5rem; /* Spacing before the source */
}


@media screen and (max-width: 768px) {
    .matching-text-1 {
        visibility:visible
    }

    .matching-text-2 {
        visibility: hidden;
        display:none
    }
}

@media screen and (min-width: 768px) {
    .matching-text-1 {
        visibility: hidden;
        display:none
    }

    .matching-text-2 {
        visibility:visible
    }
}

d-footnote {
    margin-left: -4px;
    margin-right:2px
}

d-byline {
    background: linear-gradient(54deg, rgba(246, 199, 231, .6) 0, rgba(205, 210, 236, .6) 67%, rgba(255, 234, 226, .6) 100%);
    font-size:1em;
}

d-byline h3 {
    color:rgba(0, 0, 0, .8) !important
}

d-appendix h3 {
    width:80vw
}

.flex-container {
    display: flex;
    flex-direction:row
}

@media (max-width: 768px) {
    .flex-container {
        flex-direction:column
    }
}

.mobile-50 {
    width:50%
}

.mobile-75 {
    width:75%
}

@media screen and (max-width: 768px) {
    .mobile-50 {
        width:100%
    }

    .mobile-75 {
        width:100%
    }
}

.popup {
    position: relative;
    display: inline-block;
    text-decoration: underline;
    text-decoration-style: dotted;
    cursor: help;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select:none
}

.popuptext {
    display: flex;
    flex-direction: column;
    visibility: hidden;
    width: 360px;
    background: #f5f5f5;
    color: #000;
    border-radius: 6px;
    position: absolute;
    z-index: 1;
    font-size: .8em;
    z-index: 100;
    line-height: 1.5em;
    box-shadow: rgba(99, 99, 99, .8) 0 2px 8px 0;
    font-style:normal !important
}

.popupheader {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    font-style: normal !important;
    font-size: 1.2em;
    font-weight: 700;
    background: linear-gradient(54deg, rgba(246, 199, 231, .6) 0, rgba(205, 210, 236, .6) 67%, rgba(255, 234, 226, .6) 100%);
    padding: 8px;
    cursor:default !important
}

.popupdefinition {
    padding: 6px 12px 12px 12px;
    cursor: default !important;
    font-weight:400 !important
}

.popupclose {
    font-size: 1.5em;
    font-weight: 700;
    color: rgba(0, 0, 0, .6);
    text-decoration: none;
    cursor:pointer
}

.popup .show {
    visibility: visible;
    -webkit-animation: fadeIn 1s;
    animation:fadeIn 1s
}

@-webkit-keyframes fadeIn {
    from {
        opacity:0
    }

    to {
        opacity:1
    }
}

@keyframes fadeIn {
    from {
        opacity:0
    }

    to {
        opacity:1
    }
}

.btn-outline-primary {
    border-radius:5px !important
}

.bg-dark {
    background: none !important;
}

.glass-pane {
    background: rgba(255, 255, 255, .9);
    box-shadow: 0 0 10px rgba(0, 0, 0, .2);
    border-radius: 5px;
    padding:10px
}

.card, .card-img {
    border-radius:0 !important;
    border:none;
}

.herovideo {
    background: url(images/herovideo.mp4);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    z-index:-2
}

.heroimage {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    min-height:calc(85vh - 300px)
}

@media (max-width: 768px) {
    .heroimage {
        background: url(images/.heroimage.jpg);
        background-repeat: repeat;
        background-size: cover;
        background-position: center;
        -webkit-animation-fill-mode: forwards;
        animation-fill-mode:forwards
    }

    .landingcontent {
        position:none
    }
}

#herovid {
    position: absolute;
    right: 0;
    width: 100vw;
    height: calc(85vh - 300px);
    -webkit-transform: translateX(calc((100% - 100vw) / 2));
    -ms-transform: translateX(calc((100% - 100vw) / 2));
    transform: translateX(calc((100% - 100vw) / 2));
    -o-object-fit: cover;
    object-fit:cover
}

.landingcontent {
    opacity: 0;
    top:20px
}

@keyframes hue {
    0% {
        filter:hue-rotate(0)
    }

    100% {
        filter:hue-rotate(360deg)
    }
}

.filter {
    animation: hue 4s steps(36) infinite;
    opacity:100%
}

.hideme {
    opacity:0
}

.faint {
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, .37);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border: 1px solid rgba(255, 255, 255, .18);
    margin: 10px;
    transition: .5s;
    z-index: 2;
    background:black;
}

.faint2 {
    box-shadow: 0 2px 8px 0 rgba(31, 38, 135, .37);
    backdrop-filter: blur(1px);
    -webkit-backdrop-filter: blur(1px);
    border-radius: 5px;
    border: 1px solid rgba(255, 255, 255, .18);
    transition: .5s;
    z-index: 2;
    background:#0b1520
}

.faint2:hover {
    border:1px solid #918bbb
}

.faint:hover {
    border:1px solid #918bbb
}

.stroke {
    font-family: Bitter, serif !important;
    font-weight: 900 !important;
    text-shadow: 0 0 9px #847eb9, 0 0 6px #000;
    font-size: 60px;
    line-height: 1.5;
    margin:10px
}

@media (max-width: 768px) {
    .stroke {
        font-size: 40px;
        text-shadow: 0 0 4px #847eb9, 0 0 2px #000;
        margin:25px
    }
}

.bg-light {
    background-color:rgba(11, 21, 32, .8) !important
}

.team-card {
    margin-bottom: 20px;
    border: 1px solid #ccc;
    border-radius: 5px;
    overflow:hidden;
    font-size:0.8em !important;
}

.team-card-left {
    padding:15px
}

.team-card-right {
    padding:15px
}

.team-card-img {
    width: 100%;
    height: auto;
    border-radius:50px
}

.team-card-name {
    font-family: Bitter, serif !important;
    font-size: 1.5em;
    font-weight: 700;
    margin-bottom:5px
}

.team-card-position {
    font-size: 1.2em;
    margin-bottom:5px
}

.team-card-bio {
    font-size:1em
}

.team-card-bio > a {
    color: #918bbb !important;
    text-decoration: none !important;
    font-weight:700
}

.donate-button {
    background-color: darkorange; /* Darker orange on hover/focus */
    color: white !important; /* White text */
    padding: 5px 10px; /* Padding for size */
    border: none; /* No border */
    font-weight: bold; /* Bold font */
    text-decoration: none; /* Remove underline */
    transition: background-color 0.3s, color 0.3s; /* Smooth transition for hover effects */
}

.donate-button:hover, .donate-button:focus {
    background-color: orange; /* Orange background */
    color: white !important; /* Keep text white on hover/focus */
}

@media (max-width: 768px) {
    .donate-button {
        padding: 4px 8px !important; /* Smaller padding on mobile */
    }
    
    .navbar-nav {
        margin-top: 10px; /* Add some top margin on mobile */
    }
}

.herovid-bg {
    opacity: 1;
    background: radial-gradient(circle at center, rgba(0, 0, 0, 0) 0, rgba(0, 0, 0, 0) 15%, rgba(0, 0, 0, .8) 45%, rgba(0, 0, 0, .95) 75%);
    max-height:calc(85vh - 63px)
}

.whiteshadow {
    box-shadow: 0 0 10px rgba(255, 255, 255, .2)
}


/* HEADER */

.header-container {
    background: #1a1a1a; /* Dark background for contrast */
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 30px;
    font-size: 1rem;
}

.navbar-brand {
    display: flex;
    align-items: center;
    font-family: 'Futura PT Demi', sans-serif; /* Futura PT Demi for brand */
}

.navbar-brand img {
    margin-right: 15px;
}

.navbar-nav .nav-link {
    margin-right: 20px;
    font-family: 'Futura PT Demi', sans-serif; /* Futura PT Demi for navigation */
    transition: color 0.3s; /* Transition for hover effect */
}

.navbar-nav .nav-link:hover {
    color: #e61b1b; /* Hover effect */
}

.navbar-nav .nav-link.active {
    color: #4CAF50; /* Active link color */
    font-weight: 700; /* Make active link bold */
}

@media (max-width: 992px) {
    .navbar-brand > span {
        display: none; /* Hide the full name on smaller screens */
    }

    .navbar-brand .mobile-logo {
        display: block; /* Show the short name on smaller screens */
    }
}

@media (max-width: 768px) {
    .navbar-brand img {
        height: 40px; /* Smaller logo on mobile */
    }
}

.team-card {
    height: 100%;
    background: transparent;
    margin-bottom: 0.5rem;
}

.team-image-container {
    position: relative;
    width: 100px;
    height: 100px;
    overflow: hidden;
    border-radius: 5px;
    margin-right: 1rem;
    flex-shrink: 0;
}

.team-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.team-member-info {
    flex: 1;
    min-width: 0;
    position: relative;
    padding-bottom: 0;
}

.team-member-info .card-subtitle {
    font-size: 1rem;
    line-height: 1.4;
}

.team-member-info .card-subtitle.small {
    font-size: 0.875rem;
    opacity: 0.8;
}

.card-body {
    padding: 1rem;
}

/* Update the media query styles for better mobile layout */
@media (max-width: 37.5em) { /* 600px */
    #horizontal-signup-banner .banner-content {
        padding: 0.75rem; /* Reduced padding */
        gap: 0.5rem; /* Reduced gap */
    }

    .banner-title {
        font-size: 1.25rem; /* Smaller title on mobile */
        margin-bottom: 0.25rem;
    }

    .banner-description {
        font-size: 0.9rem;
        margin-bottom: 0.75rem;
    }

    .signup-form {
        flex-direction: column;
        width: 100%;
        gap: 0.5rem; /* Reduced gap between form elements */
    }

    .signup-input {
        width: 100%;
        padding: 0.5rem;
        margin-bottom: 0;
    }

    .btn {
        width: 100%;
        padding: 0.5rem;
        margin-bottom: 0;
    }

    .news-alerts {
        margin-top: 1rem;
    }

    .news-item {
        flex-direction: row; /* Keep horizontal layout for news item */
        align-items: center;
        text-align: left; /* Keep text left-aligned */
        gap: 0.75rem;
    }

    .news-image {
        width: 2.5rem; /* Smaller image on mobile */
        height: 2.5rem;
        margin: 0; /* Remove margin */
    }

    .news-title {
        font-size: 1rem;
    }

    .news-description {
        font-size: 0.85rem;
        line-height: 1.3;
    }

    .close-button {
        top: 0.25rem;
        right: 0.25rem;
        font-size: 1.25rem;
    }
}

/* Add a new breakpoint for very small devices */
@media (max-width: 20em) { /* 320px */
    #horizontal-signup-banner .banner-content {
        padding: 0.5rem;
    }

    .banner-title {
        font-size: 1.1rem;
    }

    .news-description {
        display: none; /* Hide description on very small screens */
    }
}