@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;700&display=swap');
html{
    scroll-behavior: smooth;
}
body{
    margin: 0;
    padding: 0;
    font-family: 'Roboto', sans-serif;
    box-sizing: border-box;
    
}
h1{
    margin: 0;
    padding: 0;
}
h2{
    margin: 0;
    padding: 0;
}
h3{
    margin: 0;
    padding: 0;
}
h4{
    margin: 0;
    padding: 0;
}
h5{
    margin: 0;
    padding: 0;
}
h6{
    margin: 0;
    padding: 0;
}
p{
    margin: 0;
    padding: 0;
}


a{
    text-decoration: none;
    color: #000;
}

.container{
    max-width: 1140px;
    margin: 0 auto;
}
.row{
    display: flex;
}
.justify-content{
    justify-content: center;
}
.col-lg-12{
    width: 100%;
}
.col-lg-9{
    width: 75%;
}
.col-lg-8{
    width: 65%;
}
.col-lg-6{
    width: 50%;
}
.col-lg-4{
    width: 33.333%;
}
.col-lg-3{
    width: 25%;
}
.main{
    
    margin-top: 80px;
}
.navigation{
	width: 100%;
	background: #000E2F;
    padding: 10px 0;
    z-index: 1;
    margin-top: -80px;
    position: fixed;
}
.navigation .toggle-bar{
	display: none;
}
.navigation .row{
	display: flex;
}
.navigation .col-lg-4{
	width: 35%;
}
.navigation .col-lg-8{
	width: 65%;
}
.navigation .logo{
    padding: 16px 0;
	text-align: left;
}
.navigation .logo a{
    font-size: 28px;
    color: #fff;
}
.navigation .row .toggle-bar{
	text-align: right;
}
.navigation .menu ul{
	list-style-type: none;
	width: 100%;
	overflow: hidden;
    margin: 0;
    padding: 0;
    text-align: right;
}
.navigation .menu ul li{
	display: inline-block;

}
.navigation .menu ul li a{
	display: inline-block;
    text-decoration: none;
    color: #fff;
    padding: 12px 10px;
    font-size: 17px;
    font-weight: 400;
    margin: 10px 0;
}
.navigation .menu ul li a.active {
    color: #E4002B;
    border-bottom: 2px solid #E4002B;
}
#active {
    color: #E4002B;
    border-bottom: 2px solid #E4002B;
}
section.active {}

.hero-section{
    width: 100%;
    padding: 70px 0;
}
.hero-section .image{
    width: 40%;
}
.hero-section .image img{
    width: 95%;
    border-radius: 5px;
}
.hero-section .content{
    width: 60%;
    padding-left: 30px;
    padding-top: 40px;
}
.hero-section .content .item{
    margin-bottom: 25px;
}
.hero-section .content .item h2{
    font-size: 30px;
    margin-bottom: 10px;
}
.hero-section .content .item p{
    font-size: 18px;
    line-height: 1.6em;
}
.hero-section .content .item h3{
    font-size: 20px;
    margin-top: 10px;
}

.whats-section{
    padding: 70px 0;
}
.whats-section .content{
    max-width: 1000px;
    padding: 30px;
    margin: 0 auto;
    background: #fff;
    border: 1px solid #7C878E;
    border-radius: 5px;
}
.whats-section .content h2{
    font-size: 35px;
    text-align: center;
    margin-bottom: 30px;
}
.whats-section ul li{
    font-size: 20px;
    line-height: 1.6em;
}
.about-section{
    margin: 70px 0;
}
.about-section .image img{
    width: 90%;
    border-radius: 5px;
}
.about-section .details p{
    font-size: 16px;
    line-height: 1.5em;
    margin-bottom: 20px;
}
.about-section .details ul{
    list-style-type: decimal;
    margin: 0;
    padding: 0;
}
.about-section .details ul li{
    list-style-position: inside;
    margin-bottom: 20px;
    background: #7C878E;
    line-height: 1.5em;
    border: 1px solid #646d72;
    color: #fff;
    padding: 20px;
    border-radius: 5px;
}
.about-section .details ul li::marker{
    font-size: 20px;
    font-weight: 600;
}


section .heading h2{
    background: #7C878E;
    font-size: 40px;
    padding: 50px 20px;
    margin-bottom: 50px;
    text-align: center;
    text-transform: uppercase;

}


.cv-section{
    margin: 70px 0;
}
.cv-section .content .item{
    margin-bottom: 25px;
    background: #fff;
    padding: 40px;
    border: 1px solid #7C878E;
    border-radius: 10px;
    box-sizing: border-box;
}
.cv-section .content .item h2{
    font-size: 25px;
    text-transform: uppercase;
    margin-bottom: 15px;
}
.cv-section .content .item p{
    font-size: 18px;
    margin-bottom: 15px;
    line-height: 1.5em;
}
.cv-section .content .item i{
    display: block;
    font-size: 16px;
    margin-bottom: 15px;
    line-height: 1.5em;
}
.cv-section .row{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 30px;
}
.cv-section .card{
    background: #fff;
    padding: 30px;
    border: 1px solid #7C878E;
    border-radius: 10px;
    box-sizing: border-box;
}
.cv-section .card h2{
    font-size: 25px;
    text-transform: uppercase;
    margin-bottom: 15px;
}
.cv-section .card p{
    font-size: 18px;
    line-height: 1.5em;
}
.cv-section .download-btn{
    margin-top: 60px;
    text-align: center;
}
.cv-section .download-btn a{
    display: inline-block;
    background: #E4002B;
    color: #fff;
    font-size: 20px;
    padding: 18px 50px;
    text-align: center;
    border-radius: 5px;
    margin-top: 20px;
    transition: all .3s;
}
.cv-section .download-btn a:hover{
    background: #cf0127;
}



.research-section{
    padding: 0;
}
.research-section .content .row{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 30px;
}
.research-section .content .card{
    background: #fff;
    border: 1px solid #7C878E;
    border-radius: 5px;
    overflow: hidden;
}
.research-section .content .card .image{
    height: 220px;
}
.research-section .content .card img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.research-section .content .card .details{
    padding: 20px;
    box-sizing: border-box;
}
.research-section .content .card .details h2{
    font-size: 22px;
    margin-bottom: 20px;
}
.research-section .content .card .details h2:hover{
    color: #007cb9;
}
.research-section .content .card .details .btn{
    display: inline-block;
    margin-top: 20px;
    background: #E4002B;
    color: #fff;
    padding: 10px 20px;
    border-radius: 5px;
}
.research-section .content .card .details .btn:hover{
    background: #cf0127;
}




.publications-section{
    margin: 70px 0;
}
.publications-section .row{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 30px;

}
.publications-section .content .card{
    background: #fff;
    border: 1px solid #7C878E;
    border-radius: 10px;
    overflow: hidden;
    box-sizing: border-box;
}
.publications-section .content .card .card-header{
    background: #7C878E;
    color: #fff;
    padding: 15px 20px;
}
.publications-section .content .card .card-header h3{
    font-size: 20px;
    line-height: 1.4 em;
}
.publications-section .content .card .card-body{
    padding: 20px;
}
.publications-section .content .card .card-body p{
    line-height: 1.5em;
}
.publications-section .title-bar h2{
    text-align: center;
    font-size: 35px;
    margin-top: 20px;
    margin-bottom: 40px;
}
.publications-section .title-bar2{
    margin-top: 50px;
}
.publications-section .content .card .btn{
    display: inline-block;
    margin-left: 20px;
    margin-top: 0;
    margin-bottom: 5px;
    background: #E4002B;
    color: #fff;
    padding: 10px 20px;
    border-radius: 5px;
}
.publications-section .content .card .btn:hover{
    background: #cf0127;
}


.teaching-section{
    padding: 0;
}
.teaching-section .content .row{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 30px;
}
.teaching-section .content .card{
    background: #fff;
    border: 1px solid #7C878E;
    border-radius: 5px;
    overflow: hidden;
}
.teaching-section .content .card .image{
    height: 220px;
}
.teaching-section .content .card img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.teaching-section .content .card .details{
    padding: 20px;
    box-sizing: border-box;
}
.teaching-section .content .card .details h2{
    font-size: 22px;
    margin-bottom: 20px;
}
.teaching-section .content .card .details h2:hover{
    color: #007cb9;
}
.teaching-section .content .card .details .btn{
    display: inline-block;
    margin-top: 20px;
    background: #E4002B;
    color: #fff;
    padding: 10px 20px;
    border-radius: 5px;
}
.teaching-section .content .card .details .btn:hover{
    background: #cf0127;
}



.course-section{
    margin: 70px 0;
}
.course-section .sec-title{
    padding: 15px 0;
    border-bottom: 2px solid #ccc;
    margin-top: 20px;
    margin-bottom: 50px;
}
.course-section .sec-title h2{
    font-size: 30px;
    line-height: 1.6em;
    color: #E4002B;
}
.course-section .image{
    width: 25%;
}
.course-section .image img{
    width: 100%;
}
.course-section .details{
    width: 75%;
    padding-left: 40px;
    margin-top: -25px;
}
.course-section .details p{
    line-height: 1.7em;
}
.course-section .details h5{
    font-size: 20px;
    margin-top: 20px;
}
.course-section .details ul li{
    font-size: 16px;
    line-height: 1.7em;
}
.course-section .details .btn{
    display: inline-block;
    margin-left: 0;
    margin-top: 5px;
    margin-bottom: 5px;
    background: #E4002B;
    color: #fff;
    padding: 5px 10px;
    border-radius: 5px;
}
.course-section .details .btn:hover{
    background: #cf0127;
}
.course-section .announcements{
    margin-top: 60px;
}
.course-section .announcements h3{
    font-size: 20px;
    margin-bottom: 10px;
}
.course-section .announcements .card{
    background: #cf0127;
    padding: 20px;

}
.course-section .announcements .card p{
    line-height: 1.7em;
    font-size: 17px;
    color: #fff;
}
.course-section .announcements .card a{
    color: #fff;
    text-decoration: underline;
}



.blog-section .row{
    display: flex;
  }
  .blog-section{
    width: 100%;
  }
  .blog-section .left-side{
    width: 70%;
    padding-right: 20px;
    border-right: 1px solid #7C878E;
  }
  .blog-section .left-side .blog-content{
    margin-bottom: 70px;
  }
  .blog-section .left-side .blog-content .btn {
    display: inline-block;
    margin-top: 20px;
    background: #E4002B;
    color: #fff;
    padding: 10px 20px;
    border-radius: 5px;
  }
  .blog-section .left-side .blog-content img{
    width: 100%;
    margin-top: 10px;
    margin-bottom: 30px;
  }
  .blog-section .left-side .blog-content .date{
    font-weight: 600;
    display: block;
    margin-bottom: 15px;
  }
  .blog-section .left-side .blog-content h2{
    font-size: 25px;
    line-height: 1.5em;
    margin-bottom: 25px;
  }
  .blog-section .left-side .blog-content p{
    margin: 20px 0;
    line-height: 1.7em;
  }
  .blog-section .left-side .blog-content li{
    line-height: 1.5em;
    margin-bottom: 10px;
  }

  .blog-section .right-side{
    width: 30%;
    padding-left: 20px;
  }
  .blog-section .right-side .ads-img img{
    width: 100%;
  }
  .blog-section .right-side .item h3{
    margin-bottom: 10px;
  }
  .blog-section .right-side .item p{
    line-height: 1.6em;
  }
  .blog-section .right-side .item{
    margin-top: 25px;
  }
  .blog-section .right-side .latest-post{
    margin-top: 30px;
  }
  .blog-section .right-side .latest-post ul{
    list-style-type: none;
    margin: 0;
    padding: 0;
    margin-top: 20px;
  }
  .blog-section .right-side .latest-post ul li {
    margin-bottom: 15px;
  }
  .blog-section .right-side .latest-post ul li a{
    font-size: 16px;
    text-decoration: underline;
    line-height: 1.5em;
    color: #000E2F;
  }
  .blog-section .subscribe h3{
    font-size: 20px;
    margin-top: 40px;
    margin-bottom: 20px;
  
  }
  .blog-section .subscribe .box{
    background: #fff;
    border: 1px solid #7C878E;
    border-radius: 5px;
    padding: 20px;
    text-align: center;
  }
  .blog-section .subscribe .box p{
    font-size: 18px;
    margin-bottom: 20px;
  }
  .blog-section .subscribe .box input{
    width: 100%;
    font-size: 18px;
    padding: 10px 20px;
    background: #fff;
    border: 1px solid #7C878E;
    border-radius: 5px;
    box-sizing: border-box;
  }
  .blog-section .subscribe .box input:focus{
    outline: none;
  }
  .blog-section .subscribe .box button{
    background: #E4002B;
    padding: 12px 20px;
    margin-top: 20px;
    color: #fff;
    font-size: 18px;
    border: none;
    cursor: pointer;
    border-radius: 5px;
  }
  .blog-section .subscribe .box button:hover{
    background: #cf0127;
  }
  

.blog-article .row{
  display: flex;
}
.blog-article{
  width: 100%;
  padding-right: 20px;
}
.blog-article .blog-content{
  margin-bottom: 70px;
}
.blog-article .blog-content img{
  width: 30vw;
  height: auto;
  margin-top: 10px;
  margin-bottom: 30px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.blog-article .blog-content .date{
  font-weight: 600;
  display: block;
  margin-bottom: 15px;
}
.blog-article .blog-content h1{
  font-size: 35px;
  line-height: 1.5em;
  margin-bottom: 25px;
}
.blog-article .blog-content h2{
  font-size: 25px;
  line-height: 1.5em;
  margin-bottom: 25px;
}
.blog-article .blog-content .section h2{
  border-bottom: 3px solid #E4002B;
}
.blog-article .blog-content p{
  margin: 20px 0;
  line-height: 1.7em;
}
.blog-article .blog-content li{
  line-height: 1.5em;
  margin-bottom: 10px;
}
.blog-article .blog-content a{
  border-bottom: 2px solid #E4002B;
}
.blog-article .toc{
  margin-top: 50px;
  margin-bottom: 50px;
  border-top: 2px solid #7C878E;
  border-bottom: 2px solid #7C878E;
}

/* Nested ordered list for ToC */
.blog-article nav ol {
  counter-reset: item;
  padding-left: 2rem;
}
.blog-article nav li {
  display: block;
}
.blog-article nav li:before {
  content: counters(item, '.') ' ';
  counter-increment: item;
  padding-right: 0.85rem;
}

/* Styles for inline code or code snippets */
.blog-article code,
pre,
kbd {
  font-family: Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New',
    monospace;
  font-size: 85%;
  background: hsl(210, 28%, 93%);
}
.blog-article pre {
  padding: 1rem 1.4rem;
  max-width: 100%;
  overflow: auto;
  border-radius: 4px;
}
.blog-article pre code {
  font-size: 95%;
  position: relative;
}

/* Make footnote text smaller and left align it (looks bad with long URLs) */
.blog-article .footnotes p {
  text-align: left;
  line-height: 1.5;
  font-size: 85%;
  margin-bottom: 0.4rem;
}
.blog-article .footnotes {
  border-top: 1px solid hsl(0, 0%, 59%);
}


figcaption {
  margin-top: -2em;
  margin-bottom: 30px;
  font-size: 85%;
  padding-right: 10em;
  padding-left: 10em;
  margin-left: 30px;
  margin-right: 30px;
  text-align: center;
}



.schedule .row{
  display: flex;
}
.schedule{
  width: 100%;
  padding-right: 20px;
}
.schedule .content{
  margin-bottom: 70px;
}
.schedule .content img{
  width: 30vw;
  height: auto;
  margin-top: 10px;
  margin-bottom: 30px;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.schedule .content .date{
  font-weight: 600;
  display: block;
  margin-bottom: 15px;
}
.schedule .content h2{
  font-size: 25px;
  line-height: 1.5em;
  margin-bottom: 25px;
}
.schedule .content p{
  margin: 20px 0;
  line-height: 1.7em;
}
.schedule .content li{
  line-height: 1.5em;
  margin-bottom: 10px;
}
.schedule .content a{
  border-bottom: 2px solid #E4002B;
}

/* Course Schedule Table */

.schedule table, td, th {
  border: 1px solid #7C878E;
  padding: 15px;
  text-align: left;
}

.schedule table {
  width: 100%;
  border-collapse: collapse;
}

/* Course Schedule Buttons */

.schedule .content .btn{
    display: inline-block;
    margin-left: 0;
    margin-bottom: -5px;
    background: #E4002B;
    color: #fff;
    padding: 5px 10px;
    border-radius: 5px;
}
.schedule .content .btn:hover{
    background: #cf0127;
}

.events-section {
    margin: 70px 0;
}
.events-section .content h2{
    padding: 300px 0;
    text-align: center;
    font-size: 40px;
}
.news-section {
    margin: 70px 0;
}
.news-section .content h2{
    padding: 300px 0;
    text-align: center;
    font-size: 40px;
}

/* PUBLICATION LIST*/
.bracketed-list {
  list-style: none;
  counter-reset: item;
  text-indent: -4em;
  margin-left: 4em;
  /*display: inline-block;*/
  display: flex;
  flex-direction: column-reverse;
}


.bracketed-list li:before {
  content: "[" counter(item) "]";
  counter-increment: item;
  margin: 1em;
}

.publications-section .content .bracketed-list .btn{
    display: inline-block;
    margin-left: 20px;
    margin-top: 0;
    margin-bottom: 5px;
    background: #E4002B;
    color: #fff;
    padding: 5px 10px;
    border-radius: 5px;
    text-indent: 0;
    margin-left: 0;
}
.publications-section .content .bracketed-list .btn:hover{
    background: #cf0127;
}




@media only screen and (max-width: 768px){
    .col-lg-4{
        width: 100%;
    }
    .col-lg-6{
        width: 100%;
    }
    .col-lg-3{
        width: 100%;
    }
    .row{
        display: block;
    }
    .container{
        padding: 0 15px;
        box-sizing: border-box;
    }
    .navigation .menu ul .btn a{
        display: none;
    }
    .navigation{
        width: 100%;
    }
    
    .navigation .row{
        display: flex;
    }
    .navigation .col-lg-4{
        width: 70%;
    }
    .navigation .col-lg-8{
        width: 30%;
    }
    .navigation .logo{
        padding: 17px 0;
        padding-left: 0;
        
    }
    
    .navigation .logo a{
        font-size: 22px;
    }
    .navigation .nav-order-btn{
        display: inline-block;
        vertical-align: sub;
    }
    .navigation .nav-order-btn a{
        display: inline-block;
        font-size: 14px;
        text-align: center;
        padding: 12px 12px;
        background: #f17c00;
        color: #fff;
        text-transform: uppercase;
        font-weight: 600;
        border-radius: 5px;
        vertical-align: super;
    }
    .navigation .toggle-bar{
        display: block;
        text-align: right;
    }
    .navigation-bar{
        display: none;
    }
    .navigation .fa{
        font-size: 30px;
        color: #fff;
        padding: 17px 25px;
    }
    .navigation .menu ul{
        list-style-type: none;
        width: 100%;
        overflow: hidden;
        background: #000E2F;
        position: absolute;
        margin-left: 0;
        left: 0;
        text-align: left;
        display: none;
        margin: 0;
        padding: 0;
        z-index: 1;
        margin-top: 10px;
        border-top: 1px solid #7C878E;
    }
    
    .navigation-bar-show{
    }
    .navigation .menu ul li{
        display: block;
        border-bottom: 1px solid #828282;
    }
    .navigation .menu ul li a{
        display: inline-block;
        text-decoration: none;
        padding: 20px 25px;
        font-size: 18px;
        font-weight: 600;
        width: 100%;
        margin: 0;
    }
    .navigation .logo img{
        width: 100px;
        padding: 0 10px;
    }
    .hero-section{
        padding: 50px 0;
    }
    .hero-section .image{
        width: 100%;
    }
    .hero-section .image img{
        width: 100%;
    }
    .hero-section .content{
        width: 100%;
        padding-left: 0;
    }
    .whats-section{
        padding: 30px 0;
    }
    .whats-section .content{
        box-sizing: border-box;
    }
    .whats-section .content ul{
        padding: 10px;
        box-sizing: border-box;
    }
    section .heading h2{
        font-size: 35px;
        padding: 40px 15px;
    }
    .about-section{
        margin: 30px 0;
    }
    .about-section .image img{
        width: 100%;
    }
    .about-section .details{
        margin-top: 20px;
    }
    .cv-section .content .item{
        padding: 20px;
    }
    .cv-section .row{
        grid-template-columns: repeat(1, 1fr);
    }

    .cv-section .card{
        padding: 20px;
    }
    .cv-section .card h2{
        font-size: 22px;
    }
    .cv-section .card p{
        font-size: 16px;
    }
    .research-section .content .row {
        grid-template-columns: repeat(1, 1fr);
    }
    .publications-section .row{
        grid-template-columns: repeat(1, 1fr);
    }
    .teaching-section .content .row {
        grid-template-columns: repeat(1, 1fr);
    }
    .course-section .sec-title h2{
        font-size: 25px;
    }
    .course-section .image{
        width: 100%;
    }
    .course-section .details{
        width: 100%;
        padding-left: 0;
        margin-top: 20px;
    }
    .course-section .details ul li{
        font-size: 16px;
    }
    .blog-section .row{
        display: block;
    }
    .blog-section .left-side{
        width: 100%;
        border-right: none;
        padding-right: 0;
    }
    .blog-section .left-side .blog-content{
        margin-bottom: 30px;
    }
    .blog-section .left-side .blog-content h2{
        font-size: 20px;
    }
    .blog-section .right-side{
        width: 100%;
        padding-left: 0;
    }
    .news-section .content h2{
        font-size: 30px;
        padding: 200px 0;
    }
    .events-section .content h2{
        font-size: 30px;
        padding: 200px 0;
    }








}

