@keyframes moveInRight {
    0% {
        opacity: 0;
        transform: translateX(100px);
    }
    80% {
     
        transform: translateX(-10px);
    }
    100% {
        opacity: 1;
        transform: translate(0px);
    }
}

@keyframes moveInBottom {
    0% {
        opacity: 0;
        transform: translateY(30px);
    }
   
    100% {
        opacity: 1;
        transform: translate(0px);
    }
}
.home-page {
	overflow-x: hidden;
}
#featured {
    margin-top: 30px;
}
.home-page .container {
    width: 100%;
    max-width: 1440px;
}
#myfront-content {
    display: block
}
h2.front-heading {
    color: #990000;
    font-size: 3.2rem;
    font-weight: 800;
    text-align: center;
    font-family: Source Sans Pro,Helvetica Neue,Helvetica,Arial,sans-serif;
    margin: 0;
}

#top-banners {
    padding: 40px 0px;
    /* background: #A0C08C; */
    background: #fff;
}
#middle-banners {
    padding: 70px 30px;
    /* background: #A0C08C; */
    background: #fff;
}
#museums {
    margin-top: 3rem;
}
#museums img {
    width: 100%;
    height: auto;
    border: 5px solid white;
    box-shadow: 1px 1px 4px rgb(0 0 0 / 10%);
}
#museums h4 {
    text-align: center;
    font-size: 1.6rem;

}
.grid-4 {
    display: grid;
    
    grid-template-columns: repeat(4, 1fr);
    grid-row-gap: 40px;
    grid-column-gap: 20px; 
}
.grid-height-300 {
    grid-template-rows: 300px;
}
@media only screen and (max-width: 960px) {
	
    .grid-4 {    
		grid-template-rows: auto auto;
		grid-template-columns: 1fr 1fr;
		grid-row-gap: 30px;
		grid-column-gap: 20px; 
	}

}

#banners-container-1 {
    max-width: 1440px;
    margin: 0 auto;
    display: grid;
    grid-template-rows: 175px 175px;
    grid-template-columns: repeat(3, 1fr);
    grid-row-gap: 20px;
    grid-column-gap: 20px; 
}
#banners-container-2 {
    background-color: #fff;
    max-width: 1440px;
    margin: 0 auto;
    display: grid;
    grid-template-rows: 175px 175px;
    grid-template-columns: repeat(3, 1fr);
    grid-row-gap: 20px;
    grid-column-gap: 20px; 
}

#banners-container-2-alter {
    background-color: #fff;
    max-width: 1440px;
    margin: 0 auto;
    display: grid;
    grid-template-rows: 175px 175px;
    grid-template-columns: repeat(4, 1fr);
    grid-row-gap: 12px;
    grid-column-gap: 10px;
}

/* Κάτω banners   */
#banners-container-3 {    
    background-color: #fff;
    max-width: 1440px;
    margin: 40px auto;
    display: grid;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr 2fr 1fr;
    grid-row-gap: 20px;
    grid-column-gap: 20px; 
}
.sig-container {
    margin-top: 20px;

}
#sig img {
    width: 100%;
}

.e-news {
    background-color: #8f8f8f;
}

.e-news h3 {
    text-align: center;
    color: white;
    margin-bottom: 30px;
}

.e-news-grid {
    width: 100%;
    margin: 0 auto;
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: 1fr 1fr 1fr;
    grid-row-gap: 15px;
    grid-column-gap: 0px; 
}
.e-magazine {
    text-align: center;
	padding: 20px;
}
.e-magazine .magazine-container { 
	
}
.e-magazine .magazine-container img {
	max-height: 320px;
	width: 100%;
	max-width: 220px;
	margin: 10px;
	box-shadow: rgba(0,0,0,.4) 0px 0px 50px;
	transition: all 0.4s;
}	
.e-magazine .magazine-container img:hover {
 transform: rotateY(2deg);
 transform: scaleX(1.02);
 box-shadow: rgba(0,0,0,.4) 20px 33px 40px;
}

#banners-container-3 .e-news {
    padding: 0 35px 0 10px;
    grid-row: 1 / 3;

    grid-column: 2 / 3;
}
#banners-container-3 .small-banner-container {
    grid-row: 1 / 3;
    grid-column: 3 / 4;
}
#banners-container-3 .important-issues {
    grid-row: 1 / 3;
    grid-column: 1 / 2;
}
#banners-container-3 .important-issues-container {
    grid-row: 1 / 3;
    grid-column: 1 / 2;
}

#featured-news {
    padding: 20px 0px;
    background-color: #f3f4f4;
}

#banners-container-3 .small-banner img {
    width: 100%;    
    margin: 20px;
}  



@media only screen and (max-width: 860px) {
   
    #banners-container-3 {    
		grid-template-rows: auto auto auto auto;
		grid-template-columns: 1fr;
		grid-row-gap: 30px;
		grid-column-gap: 20px; 
	}
	#banners-container-3 .e-news {
		grid-row: 1 / 2;
		grid-column: 1 / 2;
	}
	#banners-container-3 .important-issues-container {
		grid-row: 2 / 3;
		grid-column: 1 / 2;
	}
    #banners-container-3 .small-banner-container {
        grid-row: 3 / 4;
        grid-column: 1 / 2;
    }
	#banners-container-3 .small-banner {		
		text-align: center;
	}
	#banners-container-3 .small-banner img {
        width: 100%;
		max-width: 250px;
		margin: 20px;
	}  
}


.banner-container {
   
}
.top-banner {
    box-shadow: 0px 0px 40px rgba(0,0,0,0.5);    
    overflow: hidden;
    position: relative;     
    
}

.top-banner span {
    position: absolute;    
    background-color: rgba(88,88,88,.4);
    color: white;
    vertical-align: middle;
    text-align: center;
    display: flex;
    z-index: 9;
    padding: 20px;
}

.top-banner.full-row span {   
    font-size: 1.9rem;
    bottom: 10%;
    left: 5%;
    width: 90%;
    height: 80%;
    align-items: center;
}

.top-banner.half-row span {  
    font-size: 1.6rem;
    bottom: 2%;
    left: 5%;
    width: 90%;
    height: 96%;
    align-items: normal;
   
}
.banner-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.banner-img.contain {
    object-fit: contain;
}
.btn-container {
    z-index: 11;
    position: relative;    
    width: 100%;    
    
}
.btn-container a {
    font-size: 1.6rem;
    position: absolute;
    text-decoration: none;  
    padding: 155px 20px 25px 20px;
    display: inline-block;  
    bottom: 0px;
    left: 0px;
    width: 100%;
    transition: all .2s;
    white-space: normal;
    border: 0;
    border-radius: 0px;
}

a.button-big {
    text-decoration: none;
    color: #fff;
    background-color: #990000;
    box-shadow: 0 0 10px rgb(0 0 0 / 10%), 0 0 5px rgb(0 0 0 / 10%);
    padding: 15px;
    display: block;    
    max-width: 240px;
    
    margin: -25px auto 50px auto;
    text-align: center;
    font-size: 1.6rem;
    transition: all 0.3s;
    border-radius: 4px;
    box-shadow: #80040a 0px 0px 3px;
}
a.button-big:hover {
    text-decoration: none;
    color: #ffe;
    background-color: #b1040e;
    transform: scale(0.98);
    box-shadow: #80040a 0px 0px 1px;    
}
a.button-big:active, a.button-big:visited  {
    text-decoration: none;
    color: #ffe;
}
.half-row .btn-container .btn {     
    padding: 5px 10px;   
    border-radius: 10px; 
    box-shadow: 0px 10px 20px rgba(0,0,0,.2);
}

.btn-container a:hover {
    transform: scale(1.05);
    
}
.btn-container .btn-black {
    background: linear-gradient(180deg,transparent,rgba(255,255,255,.85) 80%);   
    color: #222;
}
.btn-container .btn-white {
    background: linear-gradient(180deg,transparent,rgba(0,0,0,.85) 80%);   
    color: #eee;
}
.half-row .btn-container .btn-white {
    background-color: rgba(255,255,255,0.7);
    color: #000;
}
.btn-container .btn-animated {
    animation: moveInBottom .4s ease-out .75s;
    animation-fill-mode: backwards;
}
#top-banners .btn:active {
    transform: translateY(-1px);
    box-shadow: 0 5px 10px rgba(0,0,0,0.2);
}

.btn-container .btn::after {
    content: "";
    display: inline-block;
    border-radius: 100px;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    transition: all .4s;
}
.btn-container .btn:hover::after  {
    transform: scaleX(1.6);
    transform: scaleY(1.4);
    opacity: 0;
}
.label-img {
    position: absolute;
    max-width: 120px;
    top: -5px;
    left: -5px;
    z-index: 9;
}
#banners-container-1 .banner--1 {
    grid-row: 1 / 3;
    grid-column: 1 / 2;
    
}
#banners-container-1 .banner--2 {
    grid-row: 1 / 2;    
    grid-column: 2 / 3;
}
#banners-container-2-alter .banner--1 {
   
    
}
#banners-container-2 .banner--2 {
  
}
.banner--3 {
    
}
.banner--4 {
    
}
#banners-container-1 .banner--5 {
    grid-row: 2 / 3;    
    grid-column: 2 / 3;
}
.bottom-links-container {
    margin: 5px;
}

.bottom-links-container h3.program-title {
    font-size: 1.8rem;
    padding: 2px 10px;
    text-align: center;
}
.bottom-links-container ul.list-container {
   
    padding-left: 40px;
}


.bottom-links-container ul.list-container li a {
    position: relative;
    font-size: 1.7rem;
}

.bottom-links-container .list-container .list-link {
    position: relative;
    font-size: 1.6rem;    
    text-decoration: none;
    padding: 5px;
    display: block; 
    bottom: 0px;
    left: 0px;
    width: auto;
    transition: all .2s;
    white-space: normal;
    border: 0;
    border-radius: 0px
}
.bottom-links-container .list-container .list-link::before {
    content: "";
    position: absolute;
    top: 7px;
    width: 20px;
    left: -23px;
    background-image: url(https://www.uoc.gr/resources/images/tick.png);
    height: 20px;
    background-size: contain;
}

.bottom-links-container .list-container .list-link:hover {
    transform: scale(1);
    transform: translateX(2px);
}


.banner--1 {
    grid-row: 1 / 3;
    grid-column: 1 / 2;
}

@media only screen and (max-width: 960px) {
    #banners-container-1 ,#banners-container-2 {        
        display: grid;
        grid-template-rows: repeat(6, 200px);
        grid-template-columns: 100%;
        grid-row-gap: 20px;
        grid-column-gap: 20px;
    }
    #banners-container-2-alter {        
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(4, 160px);
        grid-row-gap: 20px;
        grid-column-gap: 20px;
    }
    .top-banner.full-row span {  
        font-size: 1.6rem;
        bottom: 2%;
        left: 5%;
        width: 90%;
        height: 96%;
        align-items: normal;       
    }
    .full-row .btn-container .btn {     
        
        padding: 5px 10px;   
        border-radius: 10px; 
        box-shadow: 0px 10px 20px rgba(0,0,0,.2);
    }
    .banner--1 {
        grid-row: 1 / 2;
        grid-column: 1 / 2;
    }
    #banners-container-2 .banner--2 {
       
    }
    .banner--3 {
        grid-row: 5 / 6;
        grid-column: 1 / 2;
    }
    .banner--4 {
        grid-row: 6 / 7;
        grid-column: 1 / 2;
    }
    .banner--5 {
        
    }
}



@media only screen and (max-width: 580px) {
    #banners-container-2-alter {
        
        grid-template-rows: repeat(8, 200px);
        grid-template-columns: 100%;
       
    }
}


#featured-news2 {
    padding: 20px 20px 60px 20px;
    max-width: 1440px;
    margin: 0 auto;
    display: grid;
    /* grid-template-rows: 400px 400px; */
    /*grid-template-columns: repeat(auto-fit, minmax(250px,1fr));
    grid-row-gap: 40px;
    grid-column-gap: 30px; */
    gap: 2rem;
    grid-auto-flow: dense; /* [2] */
    grid-template-columns: repeat(auto-fit, 320px); /* [1] */
    justify-content: center;
}
@media only screen and (max-width: 717px) {
    h4.lateNews_H4 a {
        font-size: 12px;
    }
    #featured-news2 {
        grid-template-columns: 180px 180px;
        grid-template-rows: repeat(4, 280px);
        grid-row-gap: 6rem;    
        grid-column-gap: 1.2rem;   
        padding-bottom: 100px; 
    }
    .lateNews {        
        height: auto;
    }
    div.lateNews_inText {
        margin-top: 0px; 
    }
    div.lateNews_img {
        height: 130px;
    }
    div.lateNews_img img {
       
        
    }

   

    div.lateNews_img img {
        width: fit-content;
    }
    .dateUpdate1 {
        width: 47px;
        height: 47px;
        padding: 7px;
        border-radius: 0px 26px 6px 0px;
        top: 104px;
        left: 0px;
    }
    #featured-news2 p {
        display: none;
    }
}
.featured-new {
    position: relative;
}

#schools {
    margin-top: -20px;
    background-image: linear-gradient(rgba(243,244,244,0.75), rgba(243,244,244,1)), url('img/Crete.jpg');  
    background-size: cover;
}
#schools h5 {
    font-size: 16px;
    padding-left: 4px;
}
#depblock {
    padding-top: 20px;
}
#deps-uoc {
    padding: 15px 20px 30px 20px;
    max-width: 1440px;
    margin: 0 auto;
    display: flex;  
    

}
.dep-uoc {
    padding: 15px;
     
}
.dep-uoc h4 {
    min-height: 40px;
    text-align: center;
    font-size: 1.7rem;
}

.dep-city {
    margin: 20px;
    box-shadow: 0px 0px 40px rgba(0,0,0,0.1);    
    border-radius: 4px;
}

.dep-city.rethymno {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    
}
.dep-city.heraklion {
    display: grid;
    grid-template-columns: repeat(2, 1fr);    
    /*
    background-image: linear-gradient(rgba(252,255,250,0.85), rgba(252,255,250,1)), url('img/her.jpg');    
    background-size: cover;
    */
}
.rethymno, .heraklion {
    position: relative;    
    padding-top: 40px;  
}
.rethymno {    
    
}
.heraklion {    
    
}
.rethymno::after, .heraklion::after {
    position: absolute;
    
    width: 100%;
    text-align: center;
    top: 12px;
    font-size: 2.4rem;
}
.rethymno::after {   
    content: "Ρέθυμνο";
}
.heraklion::after {
    content: "Ηράκλειο";
}



.dep-uoc img {
    width: 100%;
    border: 5px solid white;
    box-shadow: 1px 1px 4px rgba(0,0,0,0.1);  
    max-height: 190px;  
}
@media only screen and (max-width: 1280px) {
    #deps-uoc {
        padding: 20px 20px 40px 20px;
        text-align: center;
        display: block;
    }
    .dep-uoc h4 {        
        display: block;
        font-size: 1.5rem;
    }
    .dep-city.heraklion {
        max-width: 70%;
        margin: 0 auto;
    }
}
@media only screen and (max-width: 680px) {
    #deps-uoc {
      
    }
    .dep-uoc h4 {        
      
        font-size: 1.3rem;
    }
    .dep-city.heraklion {
      
    }
}

/*
@media only screen and (max-width: 990px) {
    #featured-news2 {
        padding: 0px 20px 60px 30px;
        
        grid-template-rows: 400px 400px 400px 400px;
        grid-template-columns: repeat(2, 1fr);
        grid-row-gap: 40px;
        grid-column-gap: 30px;
    } 
}

@media only screen and (max-width: 520px) {
    #featured-news2 {
        padding: 0px 20px 60px 60px;
        
        grid-template-rows: repeat (8, 380px);
        grid-template-columns: repeat(1, 1fr);
        grid-row-gap: 40px;
        grid-column-gap: 30px;
    } 
}
*/

.calendar-announcements {
    display: grid;
    grid-template-columns: 3fr 2fr;
    grid-row-gap: 20px;
    grid-column-gap: 20px; 
}

@media only screen and (max-width: 990px) {
    .calendar-announcements {
		
		grid-template-columns: 1fr;
		grid-row-gap: 40px;
		
	}
    #upcoming {
        
        min-height: auto;
        
    }
}


#ingenium {
    max-width: 1440px;
    text-align: center;
    padding: 30px;
    margin: 0 auto 60px auto;
    background-color: #f3f3f4;
    background-image: url("img/ingenium_map_bg.png");
    background-repeat: no-repeat;
    background-position: right -133px;
    box-shadow: rgba(0,0,0,.25) 0px 0px 60px;
}

#ingenium .logo-ingenium {
    display: inline-block;
    
    max-width: 450px;
}
#ingenium .logo-ingenium img {
    width: 100%;
}
#ingenium .text-ingenium {
    display: inline-block;   
    background-color: #f3f4f466;
    padding: 20px;
    font-size: 2.5rem;
    
}
#ingenium .text-ingenium a,  #ingenium .text-ingenium a:visited {
    color: #990000;
    transition: color 0.5s;
}
#ingenium .text-ingenium a:hover, #ingenium .text-ingenium a:active {
    text-decoration: none;
    color: #db3900;
}











/***************************** custom 2 ************************************/



.lateNews {
    background: #fff;
}
h4.lateNews_H4 a {
    color: #444444;   
}
h4.lateNews_H4 a:hover {
    color: #5a4141;   
}

.lateNews_img {
    overflow: hidden;
    background: #eee;
    border-top: 5px solid #990000;
    height: 180px;
    
}

div.lateNews_img img {
    width: fit-content;
}

@supports (-moz-appearance:none) {
    div.lateNews_img img { 
        width: auto;
     }
}
.lateNews {
    box-shadow: 10px 0px 40px rgba(0,0,0,0.2);
}

div.lateNews_inText p.calendar:after {
    
    background-image: linear-gradient(to right, rgba(153, 0, 0, 0.5), #fff);
    
}

div.lateNews_inText p.calendar {
    
    color: #444;
}
#main-featured-articles {
    max-width: 1440px;
    margin: 0 auto;
    display: grid;
    grid-template-rows: 225px 225px;
    grid-template-columns: repeat(4, 1fr);
    grid-row-gap: 20px;
    grid-column-gap: 20px;

}

.important-issues {
    border: 0px;
   
    
}
.announcementsBlock {
    box-shadow: 0px 0px 40px rgba(55,55,55,.3);
    border: 0px;
}

/*
.lateNews_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
*/

/*  CALENDAR  */
.calendarBlock h2 a {
    display: block;
    color: #7a121a;

    transition: color 0.5s;
}
.calendarBlock h2 a:hover,  .calendarBlock h2 a:active, .calendarBlock h2 a:visited{
    
    text-decoration: none;
}
.calendarBlock {
    height: auto;
    background: #fff;
    box-shadow: 0px 0px 0px #6f6f6f;
    border: 0;
    box-shadow: 0px 0px 40px rgba(55,55,55,0.2);
    border-radius: 8px;
    padding: 20px;
}
.calendarBlock #calcal table thead {
    font-size: 0.8rem;    
    border-bottom: 0px;
}
.calendarBlock #calcal table thead tr th {
    color: #dbd1d1; 
    border-bottom: 0px;
}
.calendarBlock-Head  {
    display: none;
}
.calendarBlock #calcal table {
    border-collapse:separate; 
    border-spacing: 0 1em;
}
.calendarBlock #calcal table caption a {
    display: block;
    width: 100%;
    padding-left: 50px;
    text-align: left;
    position: relative;
}
.calendarBlock #calcal table caption a::after {
    position: absolute;
    left: 0px;
    top: -10px;
    content: url("img/calendar-topleft.png");
}

.calendarBlock #calcal table tr td {
    border-top: 0px;
    font-size: 1.4rem;
    font-weight: 200;
}
.calendarBlock #calcal table tr td.activ  {
    background-color: #db3900;
    border-radius: 8px;
    box-shadow: rgba(0,0,0,0.3) 0px 0px 6px;
}
.calendarBlock #calcal table tr td a {
    position: relative;
    display: block;
}
.calendarBlock #calcal table tr td a::after {
    position: absolute;
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 100px;
    bottom: -16px;
    left: calc(50% - 4px);
    
    text-align: center;
    background-color: #db3900;
}

.empty-calendar {
	font-size: 16px;
	margin: 20px 5px;
}

#deps-uoc .departments .desc {
    background-color: white;
    box-shadow: rgba(0,0,0,0.3) 0px 0px 6px;
}
.elke-announcements {
    
    margin-bottom: 0px;
}
#myfront-content {
    background-color: white;
    padding-top: 30px;
}

.front-eif, #eif {
    
    margin-top: 0px;
}
.front-eif img {
    width: 100%;
   
}

.announcementsBlock-Head {
    background: transparent;
    
}
.announcementsBlock-Head a {
    display: block;
    color: #7a121a;
}
.announcementsBlock-Head:hover a {    
    color: black;
}

input.search-text, .important-issues {
    background: #990000;
}

#my-content {
    display: block;
}

/* *************** Images grid ************ */
.images-grid {
    display: grid;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin: auto;
    grid-template-columns: repeat( auto-fit, minmax(280px, 1fr) );
    row-gap: 25px;
    column-gap: 25px;   
    margin-bottom: 30px;
}
.images-grid.wide-340 {
    grid-template-columns: repeat( auto-fit, minmax(340px, 1fr) );
}

.images-grid.wide-480 {
    grid-template-columns: repeat( auto-fit, minmax(480px, 1fr) );
}

.images-grid--image {
    width: 100%;
    border: 4px solid white;
    height: 300px;
    overflow: hidden;        
    justify-content: center;
}
.images-grid--image img {
    object-position: middle;
    width: 100%;
    height: 100%;
    object-fit: cover;
}


.related-articles {
    margin-bottom: 35px;
}

.related-articles h4 {
    font-size: 21px;
    letter-spacing: 1px;
}
.related-articles ul li a {
    font-size: 16px;
}

#defImg.responsive-img {   
    margin: 10px 0;
    border: 12px white solid;
    box-shadow: rgb(0 0 0 / 40%) 1px 1px 8px;
}
#languages-menu img {
	width: 25px;
	margin-top: -3px;
}
#head-languages2 {
    display: none;
}
@media only screen and (max-width: 767px) {
    #head-languages2 {
        display: block;
        position: absolute;
        right: 0px;
    }

    #languages-menu {
        display: none;
    }

    #languages-menu2 li {
        display: inline;
    }

    #languages-menu2 li img {
        width: 28px;
        margin: 0px 4px;
    }

    button#top-button {
        margin-top: 50px;
    }
    #logo-image{
        margin-left: 15px;
    }
}
.summer-school {
    margin: 10px 0;
    padding: 10px;
    border: 1px solid #ddd;
    background-color: #eee;
}
.summer-school span {
    font-weight: 600;
    margin-right: 10px;
}

.summer-school h3 {
    font-size: 1.7rem;
}




#my-content {
    background-color: #eee;
}
.btn-container .top-links-container {
    position: absolute;
    width: 100%;
    height: 100px;
    top: 0px;
    background: linear-gradient(180deg,transparent,rgba(0,0,0,.85) 80%);
    color: #eee;
    height: 100%;
    padding-top: 20%;
}
.btn-container .top-links-container .links-container{
    position: absolute;
    bottom: 0px;
    padding: 15px 15px 30px 15px;
    width: 100%;
}
.btn-container .top-links-container .links-container div {
    text-align: left;
}   
.btn-container .top-links-container .links-container div a {
    font-size: 17px;
    position: relative;
    height: auto;
    padding: 5px;
    background: transparent !important;
}
#uoc-programs {
    position: relative;
}
#uoc-programs .uoc-container {
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg,transparent,rgba(0,0,0,.85) 80%);

}
.image-container {
    background: linear-gradient(180deg,transparent,rgba(0,0,0,.85) 80%);
}
#uoc-programs a, #uoc-programs h3 {
    
    color: white;
}
.bottom-links-container {
    z-index: 999;
     position: absolute; 
     bottom: 10px;
     left: 5px;
}

.bottom-links-container .list-container .list-link::before {
    
    background-image: url(https://www.uoc.gr/resources/images/tick-white.png);
    
}






#middle-banners-new {
    padding: 70px 30px;
    /* background: #A0C08C; */   
    background-color: #eaebeb;
}
#banners-container-2-new .middle-banner {
    position: relative;
    transition: all 0.3s ease-in-out;
    display: flex;
}
#banners-container-2-new .middle-banner .overlay {
    transition: all 0.3s ease-in-out;
    pointer-events: none;
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;    
    z-index: 2;
    background: linear-gradient(180deg,#6647477a,rgba(0,0,0,.85) 100%);
}
#banners-container-2-new .middle-banner .overlay::after {
    content: "";
    transition: all 0.3s ease-in-out;
    opacity: 0;
    margin: 5%;
    border: 1px white solid;
    width: 90%;
    display: block;
    height: 80%;
}
#banners-container-2-new .middle-banner:hover .overlay::after {
    opacity: 1;
}

#banners-container-2-new .middle-banner:hover .overlay {
   
    background: linear-gradient(180deg,#180c0c,rgba(0, 0, 0, 0.531) 80%);
}
#banners-container-2-new.test .middle-banner .overlay {   
    background: linear-gradient(180deg,rgba(255,255,255,0.8) 90%,rgba(201, 199, 199, 0.531) 100%);
    background: #333;
    opacity: 0.5;
}
#banners-container-2-new.test .middle-banner.opacity-transparent .overlay {   
    opacity: 0;
}
#banners-container-2-new.test .middle-banner:hover .overlay {   
    background: linear-gradient(180deg,#fffefe,rgba(201, 199, 199, 0.531) 100%);
    background: #990000;
    opacity: 0.9;
    top: 5%;
    left: 5%;
    height: 90%;
    width: 90%;
}

#banners-container-2-new  .middle-banner img {
    transition: all 0.4s ease-in-out;
}
#banners-container-2-new .middle-banner:hover img {
    transform: scale(0.98);
}

#banners-container-2-new .middle-banner a {
    font-size: 1.8rem;
    z-index: 3;
    background: transparent;    
    text-align: center;
    color: white;
    top: 0px;
    white-space: break-spaces;
}

#banners-container-2-new.test .middle-banner a {
    font-size: 1.8rem;
    z-index: 3;
    background: transparent;    
    text-align: center;
    color: white;
    top: 0px;
    white-space: break-spaces;
}
#banners-container-2-new.test .middle-banner.hidden-text a {    
    opacity: 0;
    transition: all 0.3s ease-in;
}
#banners-container-2-new.test .middle-banner.hidden-text:hover a {
    font-size: 1.8rem;
    opacity: 1;    
}

#banners-container-2-new .middle-banner a > div {
    position: absolute;
    transition: all 0.4s ease-in-out;
    top: 50%;
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 100%;
    left: 0;
    padding: 55px;
}
#banners-container-2-new.test .middle-banner:hover a > div {    
    padding: 55px 55px;
}

#programs {    
    max-width: 1440px;
    margin: 40px auto 0px auto;
    display: grid;
    grid-template-rows: 350px;
    grid-template-columns: repeat(4, 1fr);
    grid-row-gap: 12px;
    grid-column-gap: 20px;
    margin-bottom: 100px;
}
#programs .uoc-programs {
    background-color: white;
}

#programs .links-container  {
    padding: 35px 20px 20px 20px;
    text-align: center;
    
}
#programs .links-container a {
    font-size: 1.8rem;
}

#banners-container-2-new {    
    margin: 0px auto 0px auto;
    max-width: 1440px;   
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(2, 220px);
    grid-row-gap: 20px;
    grid-column-gap: 20px;
}
@media only screen and (max-width: 960px) {
    
    #banners-container-2-new {        
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(3, 190px);
        grid-row-gap: 15px;
        grid-column-gap: 15px;
    }   
    
    #banners-container-2-new .banner--1 {
        grid-row: 1 / 2;
        grid-column: 1 / 2;
    }
    #programs {    
       
        grid-template-rows: 350px 350px;
        grid-template-columns: repeat(2, 1fr);
        grid-row-gap: 12px;
        grid-column-gap: 20px;
        margin-bottom: 100px;
    }
    
}

@media only screen and (max-width: 580px) {
    #banners-container-2-new {
        
        grid-template-rows: repeat(6, 200px);
        grid-template-columns: 100%;
       
    }
    #programs {    
       
        grid-template-rows: repeat(4, 320px);
        grid-template-columns: repeat(1, 1fr);
        grid-row-gap: 25px;
        grid-column-gap: 20px;
        margin-bottom: 100px;
    }
}
