

a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

/*.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}*/

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/*---------- Built-in CSS ABOVE THIS LINE -------------*/

:root {
    --ctc-blue: rgba(60, 82, 137, 1);
    --ctc-blue-transparent: rgba(60, 82, 137, 0.25);
    --ctc-light-blue: rgba(198, 239, 240, 1);
    --ctc-light-blue-transparent: rgba(198, 239, 240, 0.25);
    --ctc-pale-blue: rgba(237, 245, 253, 1);
    --ctc-grey: rgba(243, 243, 243, 1);
    /*    --bs-border-radius: 0px !important;*/
}

*:focus {
    box-shadow: none !important;
}

html, body {
    font-family: "Montserrat", system-ui;
}

#mainSite {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

main {
    flex: 1;
}

h1 {
    background-color: var(--ctc-blue);
    color: white;
    display: inline-block;
    padding: 10px 12px;
    margin-top: 20px;
    margin-bottom: 20px;
    font-weight: 500;
    /*    font-size: 3.75rem;*/
}

h2 {
    background-color: var(--ctc-blue);
    color: white;
    display: inline-block;
    padding: 5px 7px;
    margin-top: 15px;
    margin-bottom: 15px;
    font-weight: 500;
    /*    font-size: 2.5rem;*/
}

h3 {
    font-weight: 700;
    font-size: 20px;
}

.h3-ctc-blue {
    background-color: var(--ctc-blue);
    color: #fff;
    /*    display: inline-block;*/
    padding: 5px 20px;
    margin-top: 15px;
    margin-bottom: 15px;
    font-weight: 500;
}

.h3-ctc-pale-blue {
    background-color: var(--ctc-pale-blue);
    color: #000;
    /*    display: inline-block;*/
    padding: 5px 20px;
    margin-top: 15px;
    margin-bottom: 15px;
    font-weight: 500;
}

h4 {
    font-weight: 700;
    font-size: 18px;
}

p {
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 24px;
}

details {
    transition: all 0.5s ease-out;
}

    details > summary {
        list-style: none;
    }

    details .accordion-bg {
        height: 40px;
        width: 40px;
        background-color: black;
    }

    details .accordion-arrow {
        transition: all 0.3s ease-out;
    }

    details > summary::marker, /* Latest Chrome, Edge, Firefox */
    details > summary::-webkit-details-marker /* Safari */ {
        display: none;
    }

    details:open .accordion-arrow {
        transform: rotate(90deg);
    }

    details::details-content {
        display: block;
        block-size: 0;
        overflow: hidden;
        transition-property: block-size, content-visibility;
        transition-duration: 0.5s;
        transition-behavior: allow-discrete;
    }

    details[open]::details-content {
        /* Fallback for browsers that don't support calc-size() function */
        block-size: auto;
        /* calc-size() function allows transition to height: auto; */
        block-size: calc-size(auto, size);
    }

.accordion-button:not(.collapsed) {
    color: inherit;
}
/*site wide styling*/
.ctc-bg-blue {
    background-color: var(--ctc-blue) !important;
    color: #fff !important;
}

    .ctc-bg-blue a {
        color: white;
    }

.ctc-bg-light-blue {
    background-color: var(--ctc-light-blue) !important;
    color: #000 !important;
}

    .ctc-bg-light-blue a {
        color: black;
    }

.ctc-bg-pale-blue {
    background-color: var(--ctc-pale-blue) !important;
    color: #000 !important;
}

    .ctc-bg-pale-blue a {
        color: #000;
    }

.ctc-bg-grey {
    background-color: var(--ctc-grey) !important;
    color: #000 !important;
}

.ctc-bg-blue.border-bottom {
    border-color: black;
}


.text-ctc {
    color: var(--ctc-blue);
}

.no-link-styling {
    text-decoration: none;
    cursor: pointer;
}

.ctc-link {
    margin: 0rem 1rem;
}

.navigation-arrow {
    transition: all 0.3s ease-out;
    transform: rotate(-30deg)
}

.ctc-page-dark-header {
    position: relative;
    flex-shrink: 0;
    max-width: fit-content;
    left: 7.5%;
}

.main-section {
    max-width: 1525px;
    margin: auto;
}

.navigation-arrow circle {
    transition: all 0.3s ease-out;
}

.navigation-arrow path {
    transition: all 0.3s ease-out;
}

.rounded-45 {
    border-radius: 45px;
}

.btn.ctc-bg-blue:hover {
    /*    background-color: #000 !important;*/
    /*    border-color: #000;*/
    color: #fff !important;
    /*border-color: #123456 !important;*/ /* optional, if you want the border to match */
}

/*Navigation*/
.navbar .nav-link.active {
    border-bottom: 2px solid white;
}

.navbar-blue {
    background-color: var(--ctc-blue);
}

    .navbar-blue a {
        color: white;
    }

.navbar .nav-link {
    margin-left: 1rem;
    margin-right: 1rem;
}


/*#carouselHero h1 {
    left: 25%;
}

#carouselHero .carousel-item img {
    object-fit: cover;
    object-position: center;
    overflow: hidden;
    height: calc(100vh - 72px);
}

#carouselHero .carousel-item:before {
    display: block;
    position: absolute;
    top: 0;
    width: 100vw;
    height: calc(100vh - 72px);
}
*/

.cookie-consent-wrapper {
    z-index: 99999;
    max-width: 1100px;
}

.cookie-consent-shell {
    max-width: 1100px;
    background-color: var(--ctc-pale-blue);
    border-radius: 0px;
    border: 1px solid var(--ctc-blue);
}

.carousel-container {
    display: flex;
    justify-content: center;
    align-items: center;
}

.carousel-wrapper {
    width: 100%;
}

.carousel-item {
    position: relative;
}

    .carousel-item img {
        width: 100%;
        height: auto;
        display: block;
    }

.carousel-control-prev,
.carousel-control-next {
    width: 5%;
    opacity: 100%;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
    background-color: rgba(0, 0, 0, 0.5);
    border-radius: 50%;
    padding: 20px;
}

.carousel-indicators {
    background-color: var(--ctc-light-blue);
    padding: 10px;
    /*    border-radius: 20px;*/
    bottom: 20px;
    margin: 0 auto;
    width: fit-content;
}

    .carousel-indicators [data-bs-target] {
        width: 20px;
        height: 20px;
        border-radius: 50%;
        background-color: white;
        border: none;
        margin: 0 8px;
    }

    .carousel-indicators .active {
        background-color: var(--ctc-blue);
        opacity: 1;
    }

.overlay-text1 {
    position: absolute;
    top: 26%;
    left: 7.5%;
}

.overlay-text2 {
    position: absolute;
    top: 40%;
    left: 7.5%;
}

.overlay-text3 {
    position: absolute;
    top: 54%;
    left: 7.5%;
}

.overlay-text4 {
    position: absolute;
    top: 75%;
    left: 7.5%;
    height: 4rem;
    border-radius: 15px;
}

.image-text {
    background-color: var(--ctc-blue);
    color: white;
    padding: 0px 20px;
    margin: 0;
    font-size: 60px;
    font-weight: 500;
    z-index: 10;
}

.aboutus-image-text {
    background-color: var(--ctc-blue);
    color: white;
    padding: 0px 20px;
    margin: 0;
    font-size: 20px;
    font-weight: 500;
    align-content: center;
}

/* Marqee */

/*.marquee {
    background: var(--ctc-light-blue);
    color: black;
    height: 60px;
    font-weight: 600;
    font-size: 2rem;
}*/

.marquee-container {
    background: var(--ctc-light-blue);
    color: black;
    height: 60px;
    font-weight: 600;
    font-size: 30px;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.marquee-content {
    display: inline-block;
    padding-left: 100%;
    animation: scroll 20s linear infinite;
    white-space: nowrap;
    line-height: 1;
}

@keyframes scroll {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-100%);
    }
}

.ctc-btn-blue {
    background-color: var(--ctc-blue);
    color: #fff;
    border-color: var(--ctc-blue);
}

    .ctc-btn-blue:hover {
        background-color: #000;
        color: #fff;
        border-color: #000;
    }


/* Home Page */

/*
.page-text {
    position: relative;
    max-width: 1230px;
    left: 7.5%;
    right: 7.5%;
}*/

.ctc-headers {
    position: relative;
    max-width: fit-content;
    left: 7.5%;
}

#ctc-header-dark {
    background-color: var(--ctc-blue);
    color: white;
    padding: 5px 20px;
    font-size: 2rem;
    font-weight: 500;
    margin-top: 15px;
    margin-bottom: 15px;
}

/*.medium-card-2x2 {
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
    justify-content: center;
    padding: 1rem;
}*/

.ctc-medium-card {
    flex: 1 0 50%;
    max-width: 630px;
    height: 325px;
    padding: 1rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    position: relative;
    /*    box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.75);*/
    /*    border: 1px solid #000;*/
    /*    border-radius: 45px;*/
}

/*.ctc-medium-card-dark {
    background: var(--ctc-blue);
}

.ctc-medium-card-light {
    flex: 1 0 50%;
    max-width: 630px;
    height: 325px;
    background: #F3F3F3;*/
/*    border: 1px solid #000;*/
/*    border-radius: 45px;*/
/*padding: 1rem;*/
/*    box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.75);*/
/*display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    position: relative;
}

    .ctc-medium-card-dark:hover, .ctc-medium-card-light:hover {
        box-shadow: 0px 0px 0px;
    }*/



.header-text-dark {
    background-color: var(--ctc-blue);
    color: white;
    padding: 12px;
    margin: 0;
    font-weight: 500;
}

.header-text-light {
    background-color: var(--ctc-light-blue);
    color: black;
    padding: 12px;
    margin: 0;
    font-size: 2rem;
    font-weight: 500;
}

.header-text-dark,
.header-text-light {
    position: relative;
    left: 1rem;
    top: 1rem;
}

.medium-card-image {
    position: absolute;
    max-width: 210px;
    max-height: 210px;
    width: auto;
    height: auto;
    right: 2rem;
    bottom: 2rem;
}

.card-link-container {
    position: absolute;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    left: 2rem;
    bottom: 2rem;
    text-decoration: none;
    color: inherit;
}

    .card-link-container:hover {
        opacity: 0.8;
        /* transform: translateY(-1px); */
        transition: all 0.2s ease;
    }

.card-link {
    max-width: 40px;
    max-height: 40px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    vertical-align: middle;
    margin: 23.976px 0 0 0;
    /* Had issue witnj allignment - this fForces consistent margin on all cards */
    box-sizing: border-box;
    /* Ensure consistent box model */
}

.card-link-text-dark {
    font-size: 20px;
    font-weight: 500;
    transform: translateY(20px);
    color: var(--ctc-blue);
    white-space: nowrap;
}

.card-link-text-light {
    font-size: 20px;
    font-weight: 500;
    transform: translateY(20px);
    color: white;
    white-space: nowrap;
}


#studyGoalsAccordion {
    --bs-accordion-active-bg: none;
    --bs-border-radius: 0px;
    --bs-accordion-border-radius: 0px;
    --bs-accordion-inner-border-radius: 0px;
}

    #studyGoalsAccordion .accordion-item {
        /*        border-left: 10px solid #D9D9D9;*/
        font-size: 18px;
        font-style: normal;
        font-weight: 500;
        line-height: 24px;
        border: 1px solid #D9D9D9;
    }

        #studyGoalsAccordion .accordion-item .accordion-button {
            border-radius: 0px;
            background-color: var(--ctc-pale-blue);
            font-size: 18px;
            font-style: normal;
            font-weight: 600;
            line-height: 27px;
        }

            /* Open accordion button styles */
            #studyGoalsAccordion .accordion-item .accordion-button:not(.collapsed) {
                color: #fff !important;
                background-color: var(--ctc-blue);
            }

                /* Recolor ONLY elements that actually have a stroke="" attribute (and not stroke="none") */
                #studyGoalsAccordion .accordion-item .accordion-button:not(.collapsed) svg
                :is(g, path, circle, rect, polygon, polyline, ellipse, line)[stroke]:not([stroke="none"]) {
                    stroke: #fff !important;
                }

                /* Recolor ONLY elements that actually have a fill="" attribute (and not fill="none") */
                #studyGoalsAccordion .accordion-item .accordion-button:not(.collapsed) svg
                :is(g, path, circle, rect, polygon, polyline, ellipse, line)[fill]:not([fill="none"]) {
                    fill: #fff !important;
                }
                /* Make the Bootstrap accordion chevron/arrow white when open */
                #studyGoalsAccordion .accordion-item .accordion-button:not(.collapsed)::after {
                    filter: brightness(0) invert(1);
                }

            #studyGoalsAccordion .accordion-item .accordion-button strong {
                color: var(--ctc-blue);
            }

        #studyGoalsAccordion .accordion-item .accordion-header {
        }

/*.large-card-1x1 {
    display: flex;
    align-items: center;
    justify-content: center;
}*/

.large-card {
    display: flex;
    max-width: 1300px;
    width: 100%;
    background: #F3F3F3;
    border: 2px solid #ccc;
    border-radius: 45px;
    padding: 2rem;
    box-sizing: border-box;
    gap: 2rem;
    align-items: flex-start;
    justify-content: space-between;
}

.large-card-content {
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 1rem;
    max-width: 60%;
}

.large-card-text {
    margin: 0;
    font-size: 2rem;
    font-weight: 500;
}

.large-card-link {
    display: inline-block;
    margin-top: auto;
}

.large-card-image {
    max-width: 300px;
    max-height: 250px;
    height: auto;
    width: auto;
    flex-shrink: 0;
}

.large-card-link img {
    max-width: 150px;
    height: auto;
    transition: transform 0.2s ease;
}

.large-card-link:hover img {
    transform: scale(1.05);
}

/* About Us Page */


.page-info-container {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 3rem;
    margin-top: 3rem;
    /*    margin-bottom: 3rem;*/
}

.page-info-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    /*    margin-left: 7.5%;
    margin-top: 10rem;*/
}


.page-info-header {
    /*    background-color: var(--ctc-blue);*/
    color: white;
    /*    padding: 12px;*/
    /*    margin: 0 0 1rem 0;*/
    font-size: 2rem;
    font-weight: 500;
    width: fit-content;
}

.page-info-text {
    margin: 0;
}

.page-info-image {
    /*    margin-right: 5rem;*/
}

    .page-info-image img {
        max-width: 100%;
        height: auto;
        display: block;
    }

.three-column-card-box {
    display: flex;
    justify-content: center;
    padding: 2rem 0;
}

.three-column-card {
    display: flex;
    width: 1300px;
    background: var(--ctc-blue);
    border-radius: 45px;
    padding: 3rem 2rem;
    box-sizing: border-box;
    gap: 0; /* No gap because borders used for separators */
}

.column {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: 0 2rem;
    color: white;
}

    .column:not(:last-child) {
        border-right: 1px solid rgba(255, 255, 255, 0.3);
    }

.column-text {
    flex-grow: 1;
    margin-bottom: 2rem;
}

    .column-text p {
        font-size: 0.95rem;
        line-height: 1.6;
        margin: 0;
        color: rgba(255, 255, 255, 0.9);
    }

    .column-text a {
        color: white;
    }

.column-bottom {
    margin-top: auto;
}

.three-column-card .card-link-container {
    position: relative; /* Override any absolute positioning */
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    text-decoration: none;
    color: white;
    transition: all 0.2s ease;
    left: auto; /* Reset any left positioning */
    right: auto; /* Reset any right positioning */
    bottom: auto; /* Reset any bottom positioning */
    top: auto; /* Reset any top positioning */
}


    .three-column-card .card-link-container:hover {
        transform: translateX(5px);
        opacity: 0.8;
    }

.three-column-card .card-link {
    position: relative; /* Override any absolute positioning */
    max-width: 20px;
    max-height: 20px;
    width: auto;
    height: auto;
    display: block;
    flex-shrink: 0;
    left: auto; /* Reset positioning */
    right: auto;
    bottom: auto;
    top: auto;
    margin: 0; /* Reset any margins */
}

/* Three-column specific card link text */
.three-column-card .card-link-text {
    font-size: 0.9rem;
    font-weight: 500;
    color: white;
    white-space: nowrap;
    line-height: 1;
}

.who-we-are-text {
    display: flex;
    align-items: center;
    /*    gap: 9%;*/
}

    .who-we-are-text p {
        /*        margin-right: 10%;*/
        max-width: fit-content;
    }


/*.small-card-light {
    background-color: white;
    height: 400px;
    border: 1px solid #ccc;
    border-radius: 45px;
    padding: 1rem;
    box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.75);  
}*/

.small-card-light {
    background-color: white;
    /*    height: 100%;*/
    /*    border: 1px solid #ccc;*/
    /*    border-radius: 45px;*/
    padding: 1rem;
    /*    box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.75);*/
    display: flex;
    flex-direction: column;
}

    /*.small-card-light h4 {
    margin-top: 2rem;
}

.small-card-light h3 {
    margin-top: 2rem;
}*/
    .small-card-light:hover .staff-img {
        /*        filter: none;*/
        /*        transition: filter 0.3s ease;*/
    }

    .small-card-light:hover, .small-card-light:hover {
        box-shadow: 0px 0px 0px;
    }

/*.staff-img {
    width: 50%;
    height: auto;
    object-fit: contain;    
}*/

.staff-img {
    width: 220px;
    height: 220px;
    object-fit: contain;
    display: block;
    margin: 0 auto;
    /*    border-radius: 50%;*/
    /*    filter: grayscale(100%);*/
    /*    transition: filter 0.3s ease;*/
}

.staff-modal-button {
    background-color: var(--ctc-blue);
    color: white;
}

    .staff-modal-button:hover {
        background-color: var(--ctc-light-blue);
        color: black;
    }





/*.small-card-dark {
    background-color: var(--ctc-blue);
    color:white;
    border: 1px solid #ccc;
    border-radius: 45px;
    padding: 1rem;
    box-shadow: 4px 4px 0px rgba(0, 0, 0, 0.75);
}

.small-card-dark h4 {
    margin-top: 2rem;
}

.small-card-dark h3 {
    margin-top: 2rem;
}

.small-card-dark:hover, .small-card-dark:hover {
    box-shadow: 0px 0px 0px;
}*/


/* Trial Page */


#trialFilterAccordion {
    --bs-accordion-active-bg: none;
}

    #trialFilterAccordion .accordion-item {
        border: none;
    }

        #trialFilterAccordion .accordion-item .accordion-button {
            border-radius: 0px;
            border-bottom: 2px solid var(--ctc-blue);
        }

            #trialFilterAccordion .accordion-item .accordion-button strong {
                color: var(--ctc-blue);
            }

.trial-group-icon:active {
    box-shadow: none !important;
    border: transparent !important;
}


.trial-group-icon-text {
    border-bottom: 3px solid transparent;
}

.trial-group-icon:hover ~ .trial-group-icon-text {
    border-bottom: 3px solid var(--ctc-blue);
}

.trial-group-icon.active ~ .trial-group-icon-text {
    border-bottom: 3px solid var(--ctc-blue);
}

.trial-filter {
    background-color: var(--ctc-light-blue);
    color: #000;
    border-radius: 0px;
}

    .trial-filter.active {
        background-color: var(--ctc-blue);
        color: #fff;
    }

#clearFilterButton {
    border: 4px solid var(--ctc-blue);
}

    #clearFilterButton strong {
        color: var(--ctc-blue);
    }

    #clearFilterButton:hover {
        background-color: var(--ctc-blue);
    }

        #clearFilterButton:hover strong {
            color: white;
        }

/*.trial-card {
    box-shadow: 5px 5px 0px 0px #000;
    border: 1px solid #000;
    border-radius: 45px;
}*/

.trial-card p, span {
    font-size: 18px !important;
}

.trial-card .card-text b {
    color: var(--ctc-blue);
}

/*
    .trial-card .trial-arrow {
        height: 25px;
        width: 25px;
        background-color: black;
    }*/

.ctc-button-anim {
/*    box-shadow: 5px 5px 0px 0px rgba(0, 0, 0, 0.75);*/
    border: 1px solid #D9D9D9;
    border-radius: 0px;
}

    .ctc-button-anim:hover {
/*        left: 4px;
        top: 4px;*/
        box-shadow: #fff 3px 3px 0px 0px
    }

        .ctc-button-anim:hover .navigation-arrow {
            transform: rotate(0deg)
        }


            .ctc-button-anim:hover .navigation-arrow circle {
                fill: var(--ctc-blue);
            }

            .ctc-button-anim:hover .navigation-arrow path {
                fill: #fff;
            }

.ctc-button-anim-light-border {
    border-radius: 0px;
    border: 1px solid #D9D9D9;
}

    .ctc-button-anim-light-border:hover .navigation-arrow {
        transform: rotate(0deg)
    }


.ctc-bg-blue.ctc-button-anim:hover .navigation-arrow circle {
    fill: #fff;
}

.ctc-bg-blue.ctc-button-anim:hover .navigation-arrow path {
    fill: #000;
}

.ctc-bg-grey.ctc-button-anim:hover .navigation-arrow circle {
    fill: #000;
}

.ctc-bg-grey.ctc-button-anim:hover .navigation-arrow path {
    fill: #fff;
}

.trial-group {
    position: relative;
    top: -20px;
    left: -50px;
    background-color: var(--ctc-blue);
    border-radius: 0px;
    width: 20px;
}

/*Trial Details*/

#trialDetailsBox {
    background-color: var(--ctc-blue);
    color: #fff;
    border-radius: 17px;
}

    #trialDetailsBox strong {
        color: #fff !important;
    }

    #trialDetailsBox th, #trialDetailsBox td {
        background-color: var(--ctc-blue);
        border: none;
        color: #fff;
        padding: 0px;
    }

#trialDetails p, #trialDetails span {
    font-size: 1rem !important;
}

#trialDetails b, #trialDetails strong {
    color: var(--ctc-blue);
}

#TrialDocumentAccordion {
    --bs-accordion-active-bg: none;
    --bs-accordion-active-color: none;
}

.trial-description ul li p {
    margin-bottom: 0px;
}

/*News*/

.news-card {
    /*    box-shadow: var(--ctc-blue) 4px 4px 0px 0px;
    border: 2px solid var(--ctc-blue);
    border-radius: 45px;*/
}

.news-card-large h3 {
    font-size: 1.75rem;
}

/*.news-card:hover {
    left: 5px;
    top: 5px;
    box-shadow: #fff 3px 3px 0px 0px
}*/
/*
    .news-card:hover .navigation-arrow {
        transform: rotate(0deg)
    }

        .news-card:hover .navigation-arrow circle {
            fill: var(--ctc-blue);
        }

        .news-card:hover .navigation-arrow path {
            fill: #fff;
        }*/

.news-image-container {
    overflow: hidden;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center; /* horizontal centering (optional) */
}

.news-image-container-large {
    overflow: hidden;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center; /* horizontal centering (optional) */
}

.news-image-container img {
    max-width: 237px;
    max-height: 148px;
    object-fit: cover;
    object-position: center;
}


.news-image-container-large img {
    max-width: 416px;
    max-height: 260px;
    object-fit: cover;
    object-position: center;
}


/* Publications */
.publication-year {
    position: relative;
    top: -20px;
    left: -50px;
    border-radius: 0px;
    border: 1px solid var(--ctc-blue);
}

#publicationFilterAccordion {
    --bs-accordion-active-bg: none;
}

    #publicationFilterAccordion .accordion-item {
        border: none;
    }

        #publicationFilterAccordion .accordion-item .accordion-button {
            border-radius: 0px;
            border-bottom: 2px solid var(--ctc-blue);
        }

            #publicationFilterAccordion .accordion-item .accordion-button strong {
                color: var(--ctc-blue);
            }

.publication-filter {
    background-color: var(--ctc-light-blue);
    border-radius: 0px;
}

    .publication-filter.active {
        background-color: var(--ctc-blue);
        color: white;
    }

.publication-card {
    /*    border-radius: 0px;*/
}

    .publication-card .publication-text {
        font-size: 1rem !important;
    }

    .publication-card .card-text b {
        color: var(--ctc-blue);
    }

    .publication-card .trial-link:hover {
        font-weight: 700;
    }

.publication-blue {
    background-color: var(--ctc-blue);
    color: #fff;
}


    .publication-blue .publication-year {
        background-color: var(--ctc-light-blue);
        color: #000;
    }

    .publication-blue .card-title {
        padding-bottom: 0.8rem;
        margin-bottom: 1.5rem;
        border-bottom: 1px solid #fff;
        color: #fff !important;
    }

    .publication-blue .card-subtitle {
        color: #fff !important;
    }

    .publication-blue .publication-text {
        color: #fff !important;
    }

    .publication-blue a {
        color: #fff !important;
    }

    .publication-blue .related-trial-arrow rect {
        fill: #000;
    }

    .publication-blue .related-trial-arrow path {
        fill: #fff;
    }

    .publication-blue .publication-button,
    .publication-blue .publication-button:active,
    .publication-blue .publication-button:focus {
        background-color: var(--ctc-light-blue);
        border: 1px solid var(--ctc-light-blue);
        color: #000 !important;
        /*        box-shadow: 4px 4px rgba(60, 82, 137, 0.75);*/
    }

    .publication-blue a {
        color: #fff;
    }

    .publication-blue .navigation-arrow circle {
        fill: var(--ctc-light-blue);
    }

    .publication-blue .navigation-arrow path {
        fill: #000;
    }

    .publication-blue .publication-arrow {
        height: 25px;
        width: 25px;
        background-color: black;
    }

    .publication-blue .publication-arrow {
        height: 25px;
        width: 25px;
        background-color: black;
    }

    .publication-blue a:hover .navigation-arrow {
        transform: rotate(0deg);
    }

        .publication-blue a:hover .navigation-arrow circle {
            fill: #fff;
        }

        .publication-blue a:hover .navigation-arrow path {
            fill: #000;
        }

.publication-light-blue {
    background-color: var(--ctc-light-blue);
    color: #000;
}

    .publication-light-blue .publication-year {
        background-color: var(--ctc-blue);
        color: #fff;
    }

    .publication-light-blue .card-title {
        padding-bottom: 0.8rem;
        margin-bottom: 1.5rem;
        border-bottom: 1px solid #000;
        color: #000;
    }

    .publication-light-blue .card-subtitle {
        color: #000 !important;
    }

    .publication-light-blue .publication-text {
        color: #000 !important;
    }

    .publication-light-blue a {
        color: #000 !important;
    }

    .publication-light-blue .publication-button,
    .publication-light-blue .publication-button:active,
    .publication-light-blue .publication-button:focus {
        background-color: var(--ctc-blue);
        border: 1px solid var(--ctc-blue);
        color: #fff !important;
        /*        box-shadow: 4px 4px rgba(60, 82, 137, 0.75);*/
    }

    .publication-light-blue .navigation-arrow circle {
        fill: var(--ctc-blue);
    }

    .publication-light-blue .navigation-arrow path {
        fill: #fff;
    }

    .publication-light-blue a:hover .navigation-arrow {
        transform: rotate(0deg);
    }

        .publication-light-blue a:hover .navigation-arrow circle {
            fill: #000;
        }

/*    Trainaing*/



.training-card {
    background-color: var(--ctc-blue);
    color: white;
    transition: all 0.3s ease-out;
    border-radius: 0px;
    --bs-card-border-color: var(--ctc-blue);
}

    .training-card .card-header {
        /*        border-radius: 45px 45px 0px 0px;*/
    }

    /*    .training-card .card-img-top {
        max-height: 200px;
        object-fit: cover;
        object-position: center;
    }*/
    .training-card .card-img-top {
        border-radius: 0px;
        max-height: 200px;
        object-fit: cover;
        object-position: center;
        background-color: var(--ctc-pale-blue)
    }

    .training-card .card-footer {
        border-radius: 0px 0px 45px 45px;
    }

    .training-card .training-type {
        /*        position: relative;*/
        color: #000;
        background-color: var(--ctc-light-blue);
        border-radius: 0px;
        border: 1px solid var(--ctc-blue);
        /*        width: 20px;*/
    }

    .training-card .card-footer {
        background-color: transparent;
        color: #fff;
        transition: all 0.3s ease-out;
        border: none;
    }

    .training-card .card-title {
        border-bottom: 2px solid #fff;
        transition: all 0.3s ease-out;
    }

.training-card-link:hover .training-card {
    background-color: #fff;
    color: #000;
}

    .training-card-link:hover .training-card .card-title {
        border-color: #000;
    }

    .training-card-link:hover .training-card .card-footer {
        color: #000;
    }

/* Paients Page  */

/*.patient-section-header {
    margin: 20px 0;
}*/



.patient-section-header h2 {
    margin: 0;
    white-space: nowrap;
}

.patient-cruk-logo {
    position: relative;
    bottom: 475px;
    left: 250px;
}

.patient-line-container {
    position: relative;
    display: flex;
    align-items: center;
}

.patient-header-line {
    flex-grow: 1;
    height: 2px;
    background-color: #ccc;
    position: relative;
}

.patient-header-image {
    position: absolute;
    left: 50px;
    top: 50%;
    transform: translateY(-50%);
}

.patient-header-image2 {
    position: absolute;
    left: 50px;
    top: 50%;
    transform: translateY(-70%);
}

.patient-header-image3 {
    position: absolute;
    left: 50px;
    top: 50%;
    transform: translateY(-55%);
}

.patient-header-image4 {
    position: absolute;
    left: 50px;
    top: 50%;
    transform: translateY(-61%);
}

.arrow-text {
    display: flex;
    align-items: center;
    gap: 1%;
}

.patient-left-column {
    background-color: var(--ctc-pale-blue);
    color: black;
    padding: 20px;
    margin-left: 4rem;
}

.patient-right-column {
    display: flex;
    margin-top: 1rem;
    align-items: center;
    background-color: var(--ctc-blue);
    color: white;
}

    .patient-right-column img {
        margin-right: 0.5rem;
    }

    .patient-right-column a {
        color: white;
    }

.patient-full-column {
    background-color: var(--ctc-pale-blue);
    color: black;
    padding: 20px;
    margin-left: 4rem;
    margin-right: 12px;
}


.patient-link {
    margin-right: 0.5rem;
}

.patient-info-container {
    background: var(--ctc-blue);
    border-radius: 45px;
    max-width: 60%;
    margin: 20px auto;
    padding: 10px 30px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.patient-info-box {
    text-align: center;
    color: white;
    padding: 10px;
}

.patient-info-number {
    font-weight: bold;
    margin-bottom: 10px;
    line-height: 1;
}

.patient-info-number {
    font-weight: bold;
    margin-bottom: 10px;
    line-height: 1;
    background-color: var(--ctc-light-blue);
    color: black;
    padding: 5px 10px;
    display: inline-block;
    font-size: clamp(2rem, 5vw, 3.5rem);
}

.patient-info-text {
    font-weight: 400;
    margin: 0;
    font-size: clamp(0.9rem, 2vw, 1.1rem);
}






/*Footer*/
.ctc-footer-logo {
    width: 316px;
    height: 79px;
    object-fit: contain;
}

.ctc-social-links {
    display: flex;
    padding-top: 1rem;
    align-items: center;
}
/*MEDIA QUERIES */


@media (max-width: 1600px) {
    /* Carousel */

    .image-text {
        font-size: 2.5rem;
        padding: 5px 10px;
    }

  }

@media (max-width: 1400px) {
    /* Carousel */

    .image-text {
        font-size: 2rem;
        padding: 2px 10px;
    }
}



@media (max-width: 1280px) {
    /* Carousel */

    .image-text {
        font-size: 2rem;
        padding: 2px 10px;
    }

    /* Home Page */

    #card1 {
        order: 1;
    }

    #card2 {
        order: 2;
    }

    #card3 {
        order: 4;
    }

    #card4 {
        order: 3;
    }

    /*    patient page */

    .patient-info-container {
        max-width: 75%;
    }
}

@media (max-width: 992px) {
    /* Carousel */

    .image-text {
        font-size: 1.5rem;
        padding: 2px 10px;
    }
}

@media (max-width: 768px) {

    /* Home Page*/

    /* Carousel */

    .carousel-control-prev-icon,
    .carousel-control-next-icon {
        background-color: rgba(0, 0, 0, 0.1);
        border-radius: 50%;
        padding: 20px;
    }

    .carousel-indicators [data-bs-target] {
        width: 12px;
        height: 12px;
        margin: 0 5px;
    }


    .image-text {
        font-size: 1rem;
        padding: 2px 10px;
    }

    .aboutus-image-text {
        font-size: .5rem;
        padding: 0 0 px;
    }

    .overlay-text4 {
        position: absolute;
        top: 75%;
        left: 7.5%;
        height: 2.5rem;
        width: 5rem;
        border-radius: 5px;
    }

    /* Marquee */

    .marquee-container {
        height: 30px;
        font-weight: 600;
        font-size: .8rem;
    }

    /*    .ctc-page-dark-header {
        margin-left: -3%;
    }
*/




    /* MEDIUM CARD */

    .page-text {
        margin-right: 3rem;
    }

    .ctc-medium-card {
        flex: 0 0 100%;
        /* one per row */
        /*        max-width: 95%;*/
    }

    .ctc-medium-card {
        flex: 0 0 100%;
        /* one per row */
        /*        max-width: 95%;*/
    }

    .header-text-dark {
        font-size: 1rem;
        padding: 6px 9px;
    }

    .header-text-light {
        font-size: 1rem;
        padding: 6px 9px;
    }

    .card-link {
        max-width: 30px;
        max-height: 30px;
        left: 1rem;
        bottom: 1rem;
    }

    .card-link-container {
        right: 0.8rem;
        bottom: 0.8rem;
        gap: 0.3rem;
    }

    #card1 {
        order: 1;
    }

    #card2 {
        order: 2;
    }

    #card3 {
        order: 4;
    }

    #card4 {
        order: 3;
    }

    /* LARGE CARD  */

    .large-card {
        flex-direction: column;
        height: auto;
        width: 100%;
        max-width: none;
        align-items: center;
        text-align: center;
        padding: 1.5rem;
        margin: 0 auto;
    }

    .large-card-content {
        max-width: 100%;
        align-items: center;
    }

    .large-card-text {
        font-size: 1.5rem;
    }

    .large-card-image {
        max-width: 250px;
    }

    .large-card-link {
        margin-top: 1rem;
    }

    /* About US */

    .page-info-container {
        flex-direction: column;
        gap: 1.5rem;
    }

    .page-info-content {
        /*        margin-left: 5%;*/
        order: 2;
    }

    #page-info-header {
        font-size: 1.75rem;
    }

    .page-info-image {
        display: flex;
        order: 1;
        justify-content: center;
        align-items: center;
        max-width: 80%;
        margin: 0 auto;
    }

    .three-column-card-box {
        padding: 1rem;
    }

    .three-column-card {
        flex-direction: column;
        width: calc(100% - 2px);
        max-width: 600px;
        padding: 2rem 1.5rem;
        box-sizing: border-box;
    }

    .column {
        padding: 1.5rem 0;
    }

        /* Change separators to horizontal lines when stacked */
        .column:not(:last-child) {
            border-right: none;
            border-bottom: 1px solid rgba(255, 255, 255, 0.3);
            padding-bottom: 2rem;
            margin-bottom: 1rem;
        }

    .column-text {
        margin-bottom: 1.5rem;
    }
    /*
    .who-we-are-text {
        flex-direction: column;
        align-items: flex-start;
        gap: 15px;
    }

        .who-we-are-text p {
            width: 100%;
            padding-left: 7.5%;
        }
*/
    /* PATIENT PAGE */

    .patient-left-column, .patient-full-column {
        margin: 12px;
        max-width: calc(100% - 24px);
    }

    .patient-right-column {
        font-size: 12px;
    }

    .patient-info-container {
        max-width: 90%;
        padding: 30px 20px;
    }

    .patient-info-number {
        padding: 10px 15px;
    }


    /* Footer */

    .ctc-footer-logo {
        max-width: 200px;
    }
}



@media (max-width: 576px) {

    /* Carousel */

    .carousel-control-prev-icon,
    .carousel-control-next-icon {
        background-color: transparent !important;
        padding: 0;
    }

    .image-text {
        font-size: .8rem;
        padding: 2px 10px;
    }
}

@media (max-width: 480px) {

    .image-text {
        font-size: .7rem;
        padding: 2px 10px;
    }

    .large-card {
        padding: 1rem;
        border-radius: 30px;
    }

    .large-card-text {
        font-size: 1.3rem;
    }

    .large-card-content p:not(.large-card-text) {
        font-size: 0.9rem;
    }

    .large-card-image {
        max-width: 200px;
    }

    .large-card-link img {
        max-width: 100px;
    }
}

@media (max-width: 375px) {
    .image-text {
        font-size: .6rem;
        padding: 2px 10px;
    }
}
