/* ----------INDEX---------- */
/* ----------GENERAL---------- */
/* ----------FULL SCREEN---------- */
/* ----------MENUS---------- */
/* ----------MODULE BANNERS---------- */
/* ----------DEFINITIONS---------- */
/* ----------FACULTY CARDS---------- */
/* ----------STUDENTS---------- */
/* ----------TABLES---------- */
/* ----------CONTENT TABS (SCHEDULES)---------- */
/* ----------HIGHLIGHT SECTIONS---------- */
/* ----------CUSTOM ADMONITION ECTS---------- */
/* ----------ICONS---------- */
/* ----------MEDIA QUERIES---------- */


/* ----------GENERAL---------- */

:root {
    /* --primary-color:  #4983ff; */
    --primary-color:  #32bba2;
    /* --primary-color-light-mode: #1c449a; */
    --primary-color-light-mode: #32bba2;
    --white: #fbfbfe;
    --black: #000000;
    --md-admonition-icon--ects: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 576 512"><!--! Font Awesome Free 6.4.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2023 Fonticons, Inc.--><path d="M316.9 18c-5.3-11-16.5-18-28.8-18s-23.4 7-28.8 18L195 150.3 51.4 171.5c-12 1.8-22 10.2-25.7 21.7s-.7 24.2 7.9 32.7L137.8 329l-24.6 145.7c-2 12 3 24.2 12.9 31.3s23 8 33.8 2.3l128.3-68.5 128.3 68.5c10.8 5.7 23.9 4.9 33.8-2.3s14.9-19.3 12.9-31.3L438.5 329l104.2-103.1c8.6-8.5 11.7-21.2 7.9-32.7s-13.7-19.9-25.7-21.7l-143.7-21.2L316.9 18z"/></svg>')

} 

strong {
    font-weight: 800;
}
img {
    width: 100%;
}

.md-typeset ul {
	list-style-type: square;
}

.md-typeset .hidden {
    visibility: hidden;
}

[data-md-color-scheme="primary"] {
    --md-primary-fg-color: var(--primary-color-light-mode);
    --md-accent-fg-color: var(--primary-color-light-mode);
    --md-typeset-a-color: var(--primary-color-light-mode);
    --md-primary-fg-color--light: var(--white);
    --md-primary-fg-color--dark: var(--black);
    --md-primary-fg-color--opposite: var(--black);
    --md-primary-bg-color: var(--white);
    --md-default-bg-color: var(--white);
    --md-primary-bg-color--light:#000000b3;
    --md-footer-bg-color: var(--primary-color-light-mode);
}

[data-md-color-scheme="slate"] {
    --md-primary-fg-color: var(--primary-color);
    --md-accent-fg-color: var(--primary-color);
    --md-typeset-a-color: var(--primary-color);
    --md-primary-fg-color--light: var(--white);
    --md-primary-fg-color--dark: var(--black);
    --md-primary-fg-color--opposite: var(--white);
    --md-default-bg-color: var(--black);
    --md-footer-bg-color: var(--primary-color);
    --md-footer-bg-color--dark: var(--primary-color);
}

[data-md-color-scheme="slate"][data-md-color-primary="indigo"] {
        --md-typeset-a-color: var(--primary-color);
    }

[data-md-color-scheme="primary"] .only-dark {
    display: none; /* Hide dark images in light mode */
}

[data-md-color-scheme="slate"] .only-light {
    display: none; /* Hide light images in dark mode */
}


.md-typeset h1,
.md-typeset h2,
.md-typeset h3,
.md-typeset h4,
.md-typeset h5,
.md-typeset h6 {
    font-weight: 400;
}

.md-typeset h4 {
    font-size: 18px;
    font-style: italic;
}

.md-typeset p {
    font-weight: 400;
}

.md-typeset h1 {
    font-size: 30px;
    font-weight: 400;
    line-height: 30px;
    text-align: left;
}

.md-typeset h1,
.md-typeset h2 {
    color: var(--md-primary-fg-color);
}

.md-typeset h3,
.md-typeset h4,
.md-typeset h5,
.md-typeset h6 {
    color: var(--md-typeset-color);
}

.md-main__inner {
	justify-content: center;
}

.button-container {
    display: flex;
    justify-content: center;
}
.md-typeset .md-button {
    border-radius: 10px;
}


/* ----------FULL SCREEN---------- */

button.fullscreen_button:hover{
    filter: invert(11%) sepia(100%) saturate(4334%)hue-rotate(237deg) brightness(111%) contrast(140%);
}

.md-typeset__scrollwrap{
	text-align: center;
}

.md-typeset:not(.emojione .icon-highlight .module-icon) img:not(.emojione, .logo .icon-highlight .module-icon),
.md-typeset:not(.emojione .icon-highlight .module-icon) svg:not(.emojione, .logo .icon-highlight .module-icon){
	display: flex;
	justify-content: center;
	max-width: 100% !important;
}

.md-tabs.fullscreen-mode {
    height: 0px;
    transition: .3s ease-in-out;
}

.md-tabs:not(fullscreen-mode) {
    transition: .3s ease-in-out;
}

.md-sidebar--primary.fullscreen-mode {
    width: 0px;
    transition: .3s ease-in-out;
}

.md-sidebar--secondary.fullscreen-mode {
    width: 0px;
    transition: .3s ease-in-out;
}

.md-sidebar--primary:not(.fullscreen-mode) {
    transition: .3s ease-in-out;    
}

.md-sidebar--secondary:not(.fullscreen-mode) {
    transition: .3s ease-in-out;    
}

/* ----------MENUS---------- */

.md-nav__link:focus, .md-nav__link:hover {
    text-decoration: underline;
}

.md-nav__item .md-nav__link--active {
	color: var(--md-typeset-a-color);
    font-weight: 600;
}

.md-header__button.md-logo img, .md-header__button.md-logo svg {
	fill: currentcolor;
	display: block;
	height: 1.8rem;
	width: auto;
    margin-bottom: 2px;
    margin-top: 2px;
}
.md-search__form {
    border-radius: 10px;
}

[data-md-toggle="search"]:checked ~ .md-header .md-search__form {
	border-radius: 10px 10px 0px 0px;
}

[data-md-toggle="search"]:checked ~ .md-header .md-search__output {
	border-radius: 0px 0px 10px 10px;
}

.edit-button-container {
	display: flex;
	justify-content: right;
    padding-bottom: 10px;
}
.edit-button-container .md-content__button.md-icon {
    float: none;
}



/* ----------BANNERS---------- */

/* Container holding the image and the text */
.banner-modules {
    position: relative;
    text-align: center;
    background-image: linear-gradient(to right, var(--md-accent-fg-color) , rgb(255, 255, 255));
    overflow: hidden;
}

.banner-image {
    opacity: 0.4;
    aspect-ratio: 16/9;
    object-fit: cover;
    object-position: 50% 50%;
    overflow: hidden;
}

/* Bottom left text */
.md-typeset .module-track {
    position: absolute;
    top: 25px;
    right: 25px;
    color: var(--md-primary-fg-color);
    margin: 0px;
    background-color: var(--md-primary-fg-color--light);
    padding: 7px 15px;
    border-radius: 50px;
    font-size: .5rem;
    display: inline-block;
}

.md-typeset .track-category {
    color: var(--md-primary-fg-color);
    margin: 0px;
    font-size: .8rem;
    padding-right: 5px;
    font-weight: 600;
    display: inline-block;
}

.md-typeset .track-category .module-icon {
    padding-right: 5px;
}

.md-typeset .module-title {
    position: absolute;
    bottom: 25px;
    left: 25px;
    color: var(--md-primary-fg-color--light);
    margin: 0px;
    padding-right: 35px;
}
.module-icon {
    width: 16px;
    fill: var(--md-primary-fg-color);
    display: inline-block !important;
    padding-right: 5px;
}

.banner-caption {
    text-align: right;
    font-size: 14px;
    margin: 16px 0px;
    font-style: italic;
}

.image-caption {
    text-align: right;
    font-size: 14px;
    margin-top: 0px;
    margin-bottom: 40px;
    font-style: italic;
}

/* ----------DEFINITIONS---------- */

.glossary-term code {
    color: var(--md-accent-fg-color);
    font-size: 18px;
    font-weight: 800;
    margin: 20px 0px;
}
.glossary-definition {
    padding-bottom: 30px;
}

/* ----------FACULTY CARDS---------- */

.md-typeset .faculty-card {
    display: flex;
    flex-direction: column;
}

.md-typeset.faculty-image {
    /* display: flex;
    align-content: flex-start;
    justify-content: flex-start; */
    float: left;
}

.md-typeset .faculty-card img.faculty-photo {
    float: left;
    width: 100%;
    aspect-ratio: 1;
    border-radius: 20px;
    padding: 0px;
    object-fit: cover;
    object-position: 50% 50%;
    overflow: hidden;
    margin-bottom: 40px;
    filter: grayscale(100%);
}

.md-typeset .faculty-bio {
    margin-top: 25px;
}

.md-typeset .faculty-card h4 {
    margin-top: 0px;
    font-weight: 500;
    color: var(--md-primary-fg-color);
}

.md-typeset .faculty-card h3.name {
    margin-top: 0px;
    padding-top: 0px;
    font-weight: 500;
    margin-bottom: 0px;
    color: var(--md-typeset-color);
}

.md-typeset hr.divider-faculty {
    border-bottom: 2px solid var(--md-typeset-table-color);
    margin: 50px 0px 50px 0px;
}

.socials-faculty {
    min-width: 20px;
    height: 20px !important;
    fill: var(--md-typeset-color);
    position: relative;
    opacity: 50%;
    vertical-align: bottom;
    display: inline-block;
    margin: 0px;
    padding: 0px 15px 0px 0px;
}

.faculty-content {
    display: flex;
    justify-content: space-between;
    flex-direction: column;
}

.md-typeset .faculty-content-bottom {
    margin-bottom: 5px;
    display: flex;
    flex-direction: row;
    align-items: flex-end;
}

/* ----------STUDENTS---------- */

.student-block {
	padding: 10px;
	display: flex;
	align-items: center;
	justify-content: start;
	justify-self: center;
	flex-direction: column;
	height: 330px;
}

.student-logo {
    fill: var(--md-accent-fg-color);
    width: 130px;
    padding-bottom: 10px;
}
.student-icon-container {
    width: 150px;
    height: 150px;
    background-color: rgba(255, 255, 255, 0.972);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    justify-self: center;
}
.student-image {
    width: 150px;
    aspect-ratio: 1;
    border-radius: 50%;
    padding: 0px;
    object-fit: cover;
    object-position: 50% 50%;
    overflow: hidden;
    filter: grayscale(100%);
}
.student-image-container {
    border: var(--md-accent-fg-color) solid 2px;
    border-radius: 50%;
    width: 200px;
    height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    justify-self: center;
    background-color: #ffffff;
}

.student-section {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    grid-gap: 0px;
    align-items: center;
    justify-content: start;
}
h2.student-name {
    text-align: center;
    font-size: 16px;
}

/* ----------TABLES---------- */
.md-typeset__table {
    width: 100%;
}
  
.md-typeset__table table:not([class]) {
    display: table
}

.md-typeset table:not([class]) th {
    background-color: var(--md-primary-fg-color);
    color: var(--md-primary-fg-color--light);
}

.md-typeset table:not([class]) tbody tr {
    background-color: #49ff4f29;
}

.md-typeset table:not([class]) tbody tr:hover {
    background-color: hsla(125, 100%, 64%, 0.322);
    box-shadow: 0 .05rem 0 var(--md-default-bg-color) inset;
}

/* ----------CONTENT TABS (SCHEDULES)---------- */

.md-typeset .tabbed-set {
	background-color: #49ff4f2d;
	padding: 5px 20px;
    border-radius: 10px;
}

.md-typeset .tabbed-control--next {
	background: #49ff6100;
    padding-right: 5px;
}

.md-typeset .tabbed-control--prev {
    background: #49ff8000;
}

/* ----------HIGHLIGHT SECTIONS---------- */

.icon-highlight {
    fill: var(--md-accent-fg-color);
    width: 50px;
    /* padding: 25px; */
    text-align: center;
    scale: inherit;
}

.icon-highlight-container {
    border: var(--md-accent-fg-color) solid 2px;
    border-radius: 50%;
    width: 100px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    justify-self: center;
}

.highlight-section {
    display: grid;
    grid-template-columns: 1fr;
    grid-gap: 15px;
    align-items: center;
    justify-content: center;
}

.highlight-section.overview-page {
    padding-top: 30px;
}

.highlight-block {
    background-color: #49ff5829;
    padding: 50px;
    display: grid;
    align-items: center;
    justify-self: stretch;
    align-content: center;
}
.highlight-text h3 {
    text-align: center;
    font-size: 1.5em;
    font-weight: 600;
}
.highlight-text h4 {
    text-align: center;
    /* font-style: italic; */
    font-weight: bold;
    font-size: 1.2em;
    /* text-transform: uppercase; */
}
.highlight-text p {
    text-align: center;
    margin: 5px;
    font-size: 0.95em;
    line-height: 1.4;
}

.md-typeset .highlight-block .highlight-text li {
    list-style: none;
    text-align: center;
    margin: 5px 0px;
}
.highlight-text a:hover {
    text-decoration: underline;
}

.shadow-block {
    background-color: #49ff6d29;
    padding: 50px;
    display: grid;
    align-self: center;
    text-align: center;
    font-size: 20px;
}
.shadow-block:hover {
    background-color: hsla(125, 100%, 64%, 0.322);
}

/* ----------CUSTOM ADMONITION ECTS---------- */

.md-typeset .admonition {
    border-radius: 10px;
}

.md-typeset .admonition.ects,
.md-typeset details.ects {
border-color: var(--md-accent-fg-color);
}
.md-typeset .ects > .admonition-title,
.md-typeset .ects > summary {
background-color: #00000029;
}
.md-typeset .ects > .admonition-title::before,
.md-typeset .ects > summary::before {
background-color: var(--md-accent-fg-color);
-webkit-mask-image: var(--md-admonition-icon--ects);
        mask-image: var(--md-admonition-icon--ects);
}
.admonition.ects {
    border-radius: 10px;
    border-style: solid;
    border-width: 0px 0px 0px 25px;
    background-color: #4983ff29;
}
.admonition.ects .admonition-title{
    border-radius: 0px 10px 0px 0px;
}
.admonition.ects p {
    font-size: 16px;
    font-weight: bold;
}

/* ----------ICONS---------- */

.icon-padding-right {
    padding-right: 5px;
}

.icon-padding-left {
    padding-left: 5px;
}
.icon-color {
    color: var(--md-primary-fg-color);
}

/* @keyframes heart {
    0%, 40%, 80%, 100% {
      transform: scale(1);
      opacity: 0.7;
    }
    20%, 60% {
      transform: scale(1.13);
      opacity: 1;
    }
  }
.heart {
    animation: heart 1500ms infinite;
}

@keyframes share {
    0%, 20%, 30%, 50%, 70%, 80%, 100% {
        transform: rotate(0deg) scale(1.15);
        opacity: 0.8;
    }
    25% {
        transform: rotate(10deg) scale(1.2);
        opacity: 1;
    }
    75% {
        transform: rotate(-10deg) scale(1.2);
        opacity: 1;
    }
}
.share {
    animation: share 3000ms infinite;
}

@keyframes turn {
    0%, 100% {
        transform: rotate(0deg);
    }
    40%, 50% {
        transform: rotate(50deg);
    }
}
.turn {
    animation: turn 2000ms infinite;
}

@keyframes meteor {
    0% {
        transform: rotate(-5deg) scale(0.1);
        opacity: 0;
    }
    5%{
        transform: rotate(5deg) scale(0.15);
    }
    10%{
        transform: rotate(-5deg) scale(0.2);
    }
    15%{
        transform: rotate(5deg) scale(0.25);
    }
    20% {
        transform: rotate(-5deg) scale(0.3);
    }
    25%{
        transform: rotate(5deg) scale(0.35);
    }
    30% {
        transform: rotate(-5deg) scale(0.4);
    }
    35%{
        transform: rotate(5deg) scale(0.45);
    }
    40% {
        transform: rotate(-5deg) scale(0.5);
    }
    45%{
        transform: rotate(5deg) scale(0.55);
    }
    50% {
        transform: rotate(-5deg) scale(0.6);
    }
    55%{
        transform: rotate(5deg) scale(0.65);
    }
    60% {
        transform: rotate(-5deg) scale(0.7);
    }
    65%{
        transform: rotate(5deg) scale(0.75);
    }
    70% {
        transform: rotate(-5deg) scale(0.8);
    }
    75%{
        transform: rotate(5deg) scale(0.85);
    }
    80% {
        transform: rotate(-5deg) scale(0.9);
    }
    85%{
        transform: rotate(5deg) scale(0.95);
    }
    90% {
        transform: rotate(-5deg) scale(1.0);
    }
    95%{
        transform: rotate(5deg) scale(1.05);
    }
    100% {
        transform: rotate(-5deg) scale(1.1);
        opacity: 1;
    }
}
.meteor {
    animation: meteor 3000ms infinite;
}

@keyframes brain {
      20%, 40% {
        transform: scale(1);
      }
      10%, 30%, 50%  {
        transform: scale(1.15);
      }
      60%, 80% {
        transform: scale(1.10);
      }
      70%, 90% {
        transform: scale(1.2);
      }
      0%, 100% {
        transform: scale(1.5);
      }
    0%, 100% {
        opacity: 0.1;
    }
    5%, 95% {
        opacity: 0.3;
    }
    80% {
        opacity: 1;
    }
}
.brain {
    animation: brain 6000ms infinite;
} */

/* ----------PARTNERS---------- */

#partners {
    margin-top: 50px;
    background-color: white;
    padding: 100px 50px;
    display: grid;
    grid-template-rows: auto;
    grid-gap: 100px;
    align-items: center;
    align-content: center;
    justify-content: center;
    border-width: 5px;
    border-color: var(--md-accent-fg-color);
    /* border-radius: 10px; */
    border-style: solid;
}
.partner-logo {
    display: grid;
    grid-template-rows: auto;
    align-items: center;
    justify-self: stretch;
    justify-content: center;
    justify-items: center;
    align-content: center;
    align-self: stretch;
    max-width: 200px;
}
.partner-logo img {
    aspect-ratio: initial;
}
.in-text-logo {
    width: 200px;
    padding: 20px 0px;
}

/* ----------MEDIA QUERIES---------- */

@media only screen and (min-width: 600px) {
    .banner-image {
        max-height: 63vh;
        min-height: 385px;
    }
    .md-typeset .faculty-card img.faculty-photo {
        width: 175px;
        margin-right: 20px !important;
        margin-bottom: 0px;
    }
    .md-typeset .faculty-card h2 {
        padding-top: 12px;
    }
    .md-typeset h1 {
        font-size: 50px;
        line-height: 50px;
    }
    .md-typeset .faculty-card {
        display: initial;
        padding-top: 50px;
    }
    .faculty-content {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        height: 175px;
    }
    #partners {
        padding: 50px;
        grid-template-columns: 1fr 1fr 1fr 1fr;
        grid-template-rows: 100px 100px;
        grid-gap: 50px;
    }
    .partner-logo {
        aspect-ratio: 1/1;
    }
    .partner-logo img.partner-horizontal {
        aspect-ratio: initial;
        width: 100%;
        height: auto;
    }
    .partner-logo img.partner-vertical {
        aspect-ratio: initial;
        height: 100%;
        width: auto;
    }
    .partner-logo img.partner-square {
        aspect-ratio: initial;
        height: 90%;
        width: auto;
    }
}

@media only screen and (min-width: 800px) {
    .md-typeset h1 {
        font-size: 70px;
        line-height: 70px;
    }
    .md-typeset .module-title {
        padding-right: 275px;
	left: 35px;
    }
}

@media only screen and (min-width: 960px) {
    /* TOC MENU PADDING */
    .md-sidebar--secondary .md-sidebar__scrollwrap {
        display: flex;
        justify-content: center;
        align-items: flex-end;
        padding-bottom: 40px;    
    }
    .md-nav--secondary .md-nav__title {
        background: none;
        box-shadow: none;
        position: sticky;
        top: 0;
        z-index: 1;
    }
    .md-nav.md-nav--secondary{
        border-color:  var(--md-primary-fg-color);
        border-radius: 10px;
        border-width: 2px;
        border-style: solid;
        background-color: #06340ea6;
        padding: 20px 10px;
    }

    .highlight-block {
        background-color: #06340ea6;
        display: grid;
        grid-template-rows: auto;
        align-items: flex-start;
        justify-self: stretch;
        align-content: flex-start;
        align-self: stretch;
    }
    .md-content {
        max-width: 75%;
    }
}
@media only screen and (min-width: 1100px) {
    .highlight-section {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: 1fr 1fr;
    }
}
