:root {
    --spirit-purple: #4b2e83;
    --husky-purple: #32006e;
    --col-base: 8.333%;
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
}

.people-cards .card-img-top {
    aspect-ratio: 1/1;
    object-fit: cover;
    object-position: center top;
}

.people-cards .card-body h3 {
    color: var(--husky-purple);
    text-decoration: none;
}
.people-cards .card-body:hover h3 {
    text-decoration: underline;
}

.people-cards .card,
.member-labs .card {
    transition: all 0.125s ease-in-out;
}

.member-labs h3 {
    font-size: 1.125rem;
    font-weight: 600;
}


.member-labs .card img {
    border-radius: 50%;
    height: 3.5rem;
    width: auto;
}


.news-cards .card {
    max-width: 540px;
    transition: all 0.125s ease-in-out;
}

.news-cards .card h2 {
    font-size: 1.325rem;
    font-weight: 700;
}

.news-cards .card:hover,
.people-cards .card:hover,
.member-labs .card:has(a):hover {
    box-shadow: 0 0.25rem 0.25rem rgba(75, 46, 131, 0.5) !important;
}

.news-cards .card:hover h2,
.member-labs .card:has(a):hover h3 {
    text-decoration: underline;
    color: var(--husky-purple);
}


.card-grid-block *:not(.img-icon) {
    position: relative;
    z-index: 1;
}

.img-icon {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100% !important;
    z-index: 0;
    padding: .25rem 0;
}



/* Mimicking Bootstrap - this might not be perfect but it's good neough*/

.d-flex {
    display: flex !important;
}

.d-inline-flex {
    display: inline-flex !important;
}

.flex-row {
    flex-direction: row !important;
}

.flex-column {
    flex-direction: column !important;
}

@media (min-width: 576px) {
    .flex-sm-row       { flex-direction: row !important; }
    .flex-sm-column    { flex-direction: column !important; }
}

@media (min-width: 768px) {
    .flex-md-row       { flex-direction: row !important; }
    .flex-md-column    { flex-direction: column !important; }
}

@media (min-width: 992px) {
    .flex-lg-row       { flex-direction: row !important; }
    .flex-lg-column    { flex-direction: column !important; }
}

@media (min-width: 1200px) {
    .flex-xl-row       { flex-direction: row !important; }
    .flex-xl-column    { flex-direction: column !important; }
}

@media (min-width: 1400px) {
    .flex-xxl-row      { flex-direction: row !important; }
    .flex-xxl-column   { flex-direction: column !important; }
}

.row {
    display: flex;
    flex-wrap: wrap;
    margin-right: calc(-0.5 * var(--bs-gutter-x));
    margin-left: calc(-0.5 * var(--bs-gutter-x));
    margin-top: calc(-1 * var(--bs-gutter-y));
}

.row > * {
    flex-shrink: 0;
    width: 100%;
    max-width: 100%;
    /*padding-right: calc(0.5 * var(--bs-gutter-x));*/
    /*padding-left: calc(0.5 * var(--bs-gutter-x));*/
    margin-top: var(--bs-gutter-y);
}

/* Base columns (xs, no breakpoint infix) */

.col {
    flex: 1 0 0%;
}

.col-auto {
    flex: 0 0 auto;
    width: auto;
}

/* 12-column fractions */
.col-1 {
    flex: 0 0 auto;
    width: 8.333333%;
}
.col-2 {
    flex: 0 0 auto;
    width: 16.666667%;
}
.col-3 {
    flex: 0 0 auto;
    width: 25%;
}
.col-4 {
    flex: 0 0 auto;
    width: 33.333333%;
}
.col-5 {
    flex: 0 0 auto;
    width: 41.666667%;
}
.col-6 {
    flex: 0 0 auto;
    width: 50%;
}
.col-7 {
    flex: 0 0 auto;
    width: 58.333333%;
}
.col-8 {
    flex: 0 0 auto;
    width: 66.666667%;
}
.col-9 {
    flex: 0 0 auto;
    width: 75%;
}
.col-10 {
    flex: 0 0 auto;
    width: 83.333333%;
}
.col-11 {
    flex: 0 0 auto;
    width: 91.666667%;
}
.col-12 {
    flex: 0 0 auto;
    width: 100%;
}

/* --------------------------------------
   Breakpoints
   sm: 576px
   md: 768px
   lg: 992px
   xl: 1200px
   xxl: 1400px
--------------------------------------- */

/* SM ≥ 576px */
@media (min-width: 576px) {
    .col-sm {
        flex: 1 0 0%;
    }
    .col-sm-auto {
        flex: 0 0 auto;
        width: auto;
    }

    .col-sm-1 {
        flex: 0 0 auto;
        width: 8.333333%;
    }
    .col-sm-2 {
        flex: 0 0 auto;
        width: 16.666667%;
    }
    .col-sm-3 {
        flex: 0 0 auto;
        width: 25%;
    }
    .col-sm-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }
    .col-sm-5 {
        flex: 0 0 auto;
        width: 41.666667%;
    }
    .col-sm-6 {
        flex: 0 0 auto;
        width: 50%;
    }
    .col-sm-7 {
        flex: 0 0 auto;
        width: 58.333333%;
    }
    .col-sm-8 {
        flex: 0 0 auto;
        width: 66.666667%;
    }
    .col-sm-9 {
        flex: 0 0 auto;
        width: 75%;
    }
    .col-sm-10 {
        flex: 0 0 auto;
        width: 83.333333%;
    }
    .col-sm-11 {
        flex: 0 0 auto;
        width: 91.666667%;
    }
    .col-sm-12 {
        flex: 0 0 auto;
        width: 100%;
    }
}

/* MD ≥ 768px */
@media (min-width: 768px) {
    .col-md {
        flex: 1 0 0%;
    }
    .col-md-auto {
        flex: 0 0 auto;
        width: auto;
    }

    .col-md-1 {
        flex: 0 0 auto;
        width: 8.333333%;
    }
    .col-md-2 {
        flex: 0 0 auto;
        width: 16.666667%;
    }
    .col-md-3 {
        flex: 0 0 auto;
        width: 25%;
    }
    .col-md-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }
    .col-md-5 {
        flex: 0 0 auto;
        width: 41.666667%;
    }
    .col-md-6 {
        flex: 0 0 auto;
        width: 50%;
    }
    .col-md-7 {
        flex: 0 0 auto;
        width: 58.333333%;
    }
    .col-md-8 {
        flex: 0 0 auto;
        width: 66.666667%;
    }
    .col-md-9 {
        flex: 0 0 auto;
        width: 75%;
    }
    .col-md-10 {
        flex: 0 0 auto;
        width: 83.333333%;
    }
    .col-md-11 {
        flex: 0 0 auto;
        width: 91.666667%;
    }
    .col-md-12 {
        flex: 0 0 auto;
        width: 100%;
    }
}

/* LG ≥ 992px */
@media (min-width: 992px) {
    .col-lg {
        flex: 1 0 0%;
    }
    .col-lg-auto {
        flex: 0 0 auto;
        width: auto;
    }

    .col-lg-1 {
        flex: 0 0 auto;
        width: 8.333333%;
    }
    .col-lg-2 {
        flex: 0 0 auto;
        width: 16.666667%;
    }
    .col-lg-3 {
        flex: 0 0 auto;
        width: 25%;
    }
    .col-lg-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }
    .col-lg-5 {
        flex: 0 0 auto;
        width: 41.666667%;
    }
    .col-lg-6 {
        flex: 0 0 auto;
        width: 50%;
    }
    .col-lg-7 {
        flex: 0 0 auto;
        width: 58.333333%;
    }
    .col-lg-8 {
        flex: 0 0 auto;
        width: 66.666667%;
    }
    .col-lg-9 {
        flex: 0 0 auto;
        width: 75%;
    }
    .col-lg-10 {
        flex: 0 0 auto;
        width: 83.333333%;
    }
    .col-lg-11 {
        flex: 0 0 auto;
        width: 91.666667%;
    }
    .col-lg-12 {
        flex: 0 0 auto;
        width: 100%;
    }
}

/* XL ≥ 1200px */
@media (min-width: 1200px) {
    .col-xl {
        flex: 1 0 0%;
    }
    .col-xl-auto {
        flex: 0 0 auto;
        width: auto;
    }

    .col-xl-1 {
        flex: 0 0 auto;
        width: 8.333333%;
    }
    .col-xl-2 {
        flex: 0 0 auto;
        width: 16.666667%;
    }
    .col-xl-3 {
        flex: 0 0 auto;
        width: 25%;
    }
    .col-xl-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }
    .col-xl-5 {
        flex: 0 0 auto;
        width: 41.666667%;
    }
    .col-xl-6 {
        flex: 0 0 auto;
        width: 50%;
    }
    .col-xl-7 {
        flex: 0 0 auto;
        width: 58.333333%;
    }
    .col-xl-8 {
        flex: 0 0 auto;
        width: 66.666667%;
    }
    .col-xl-9 {
        flex: 0 0 auto;
        width: 75%;
    }
    .col-xl-10 {
        flex: 0 0 auto;
        width: 83.333333%;
    }
    .col-xl-11 {
        flex: 0 0 auto;
        width: 91.666667%;
    }
    .col-xl-12 {
        flex: 0 0 auto;
        width: 100%;
    }
}

/* XXL ≥ 1400px */
@media (min-width: 1400px) {
    .col-xxl {
        flex: 1 0 0%;
    }
    .col-xxl-auto {
        flex: 0 0 auto;
        width: auto;
    }

    .col-xxl-1 {
        flex: 0 0 auto;
        width: 8.333333%;
    }
    .col-xxl-2 {
        flex: 0 0 auto;
        width: 16.666667%;
    }
    .col-xxl-3 {
        flex: 0 0 auto;
        width: 25%;
    }
    .col-xxl-4 {
        flex: 0 0 auto;
        width: 33.333333%;
    }
    .col-xxl-5 {
        flex: 0 0 auto;
        width: 41.666667%;
    }
    .col-xxl-6 {
        flex: 0 0 auto;
        width: 50%;
    }
    .col-xxl-7 {
        flex: 0 0 auto;
        width: 58.333333%;
    }
    .col-xxl-8 {
        flex: 0 0 auto;
        width: 66.666667%;
    }
    .col-xxl-9 {
        flex: 0 0 auto;
        width: 75%;
    }
    .col-xxl-10 {
        flex: 0 0 auto;
        width: 83.333333%;
    }
    .col-xxl-11 {
        flex: 0 0 auto;
        width: 91.666667%;
    }
    .col-xxl-12 {
        flex: 0 0 auto;
        width: 100%;
    }
}

.card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: auto;

    background-color: #fff;
    background-clip: border-box;
    border: 1px solid rgba(0, 0, 0, .125);
    border-radius: 0.375rem;
}

.card-body {
    flex: 1 1 auto;
    padding: 1rem 1rem;
}

.card-header {
    padding: 0.5rem 1rem;
    margin-bottom: 0;
    background-color: rgba(0, 0, 0, .03);
    border-bottom: 1px solid rgba(0, 0, 0, .125);
}

.card-footer {
    padding: 0.5rem 1rem;
    background-color: rgba(0, 0, 0, .03);
    border-top: 1px solid rgba(0, 0, 0, .125);
}

.card-img-top {
    width: 100%;
    border-top-left-radius: calc(0.375rem - 1px);
    border-top-right-radius: calc(0.375rem - 1px);
    display: block;
}

.card-img-bottom {
    width: 100%;
    border-bottom-left-radius: calc(0.375rem - 1px);
    border-bottom-right-radius: calc(0.375rem - 1px);
    display: block;
}

.card-title {
    margin-bottom: 0.5rem;
}

.card-text:last-child {
    margin-bottom: 0;
}
