/* ------------------------------------------------------------------------
TABLES
------------------------------------------------------------------------ */
div.table{
    overflow-x: auto;
}
table{
    width:100%;
    border-collapse: collapse;
    border: 1px solid var(--clr-gray-1-70);
}
table caption{
    font-style: italic;
    caption-side: bottom;
    text-align: right;
    font-size: 1.4rem;
}
/* Table header */
table th{
    padding:1rem 2rem;
    background-color: var(--clr-1);
    color:var(--clr-white);
    font-weight: var(--fw-bold);
    text-align: left;
}

/* Table body rows */
table tbody tr{
    transition: background-color 0.75s ease;
}
table tbody tr:nth-child(odd){
    background-color: var(--clr-gray-1-60);
}
table tbody tr:nth-child(even){
    background-color: var(--clr-gray-1-40);
}
table tbody tr:hover{
    background-color: var(--clr-white);
    transition: background-color 0.5s ease;
}

/* Table body cell */
table tr td{
    padding:1rem 2rem;
    text-align: left;
    color:var(--clr-1-60);
}



/* ------------------------------------------------------------------------
FORM STYLING
------------------------------------------------------------------------ */
form.default{
    background-color: var(--clr-gray-1-40);
    border:solid 1px var(--clr-gray-1-70);
    border-radius: 5px;
    padding:3rem;
    display:grid;
    gap:2rem 3rem;
    grid-template-areas:
        "col1 col2";
    grid-template-columns: 1fr 1fr;
    /*box-shadow: 0 0 3px 0 var(--clr-black);*/
}
form.default div > label:first-child{
    font-size: 1.4rem;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--clr-1);
}
form.default div.span{
    column-span: all;
    grid-column-start: col1;
    grid-column-end: col2;
}
form.default div.form-name{
    display: grid;
    gap:2rem 3rem;
    grid-template-areas:
        "col1 col2 col3";
    grid-template-columns: 1fr 1fr 1fr;
    grid-column-end: -1;
}
form.default h2{
    color: var(--clr-1);
}
form.default h3{
    color: var(--clr-1);
}
form.default p{
    padding-top:1rem;
}
form.default div.diploma span:not(:last-child){
    padding-right:2rem;
}
form.default input[type="text"],
form.default input[type="password"],
form.default input[type="email"],
form.default input[type="tel"],
form.default input[type="date"],
form.default select{
    background-color: var(--clr-white);
    border: solid 1px var(--clr-gray-1-70);
    border-radius: 5px;
    padding: 0.9rem 1rem;
    width:100%;
    font-size: 1.6rem;
    font-weight: 300 !important;
    font-family: Poppins;
    color:var(--clr-black);
}
form.default select{
    font-family: 'Poppins', sans-serif;
    font-size: 1.6rem;
}
form.default input[type="text"]:focus,
form.default input[type="text"]:focus,
form.default input[type="email"]:focus,
form.default input[type="tel"]:focus,
form.default textarea:focus{
    outline: solid 1px var(--clr-1);
}
form.default textarea{
    background-color: var(--clr-white);
    border: solid 1px var(--clr-gray-1-70);
    border-radius: 5px;
    padding: 0.9rem 1rem;
    width:100%;
    font-size: 1.8rem;
    font-weight: 300;
    font-family: Poppins;
    color:var(--clr-black);
    resize:vertical;
    overflow: auto;
    /*aspect-ratio: 6 / 1;*/
}
form.default button,
form.default input[type="submit"]{
    width:100%;
    padding:1rem 1rem;
    font-weight:600;
    background-color: var(--clr-2);
    border-radius:5px;
    cursor: pointer;
    color: var(--clr-white);
    font-size: 1.8rem;
    transition: background-color 1s ease;
    font-family: Poppins;
}
form.default button:hover,
form.default input[type="submit"]:hover{
    background-color: var(--clr-2-40);
    transition: background-color 0.5s ease;
}
form.default .spaceAbove{
    padding-top:3rem;
}
button{
    cursor:pointer;
}
@media only screen and (max-width: 768px) {
    form.default{
        grid-template-areas:
            "col1 col1";
    }
    form.default div,
    form.default div.span{
        column-span: all;
        grid-column-start: col1;
        grid-column-end: col1;
    }
    form.default div.form-name{
        grid-template-areas:
            "col1 col1 col1";
        column-span: all;
        grid-column-start: col1;
        grid-column-end: col1;
    }
    form.default div.diploma span{
        padding-right:0rem;
        
        display: block;
    }
    form.default div.diploma span:not(:last-child){
        padding-bottom:1rem;
    }
    form.default textarea{
        aspect-ratio: 4 / 1;
        min-height: 100px;
    }
}



/* ------------------------------------------------------------------------
ADVERT
------------------------------------------------------------------------ */
.advert {
    display: flex;
    align-items: center;
    justify-items: center;
    border-radius: 5px;
}
.advert div{
    width:100%;
    text-align: center;
    padding: 3rem;
    background-color: var(--color-main);
}
.advert div > *:not(:first-child){
    margin-top:2rem;
}



/* ------------------------------------------------------------------------
COURSES PAGE
------------------------------------------------------------------------ */
.courses{
    gap:3rem;
    display:grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}
.courses .shout-out{
    aspect-ratio: 3 / 2;
}
.course{
    background-position: center;
    background-size: cover;
    border-radius: 5px;
    -webkit-transition: -webkit-filter 0.5s ease;
    transition: filter 0.5s ease;
}
.course a{
    display: flex;
    padding: 3rem;
    color: var(--clr-white);
    text-decoration: none;
    text-shadow: 0 0 5px var(--clr-black);
    aspect-ratio: 3 / 2;
    align-items: flex-end; 
}
.course:hover{
    -webkit-filter: none;
    filter:none;
    -webkit-transition: -webkit-filter 1s ease;
    transition: filter 1s ease;
}



/* ------------------------------------------------------------------------
SUCCESSES PAGE
------------------------------------------------------------------------ */
.success-stories{
    gap:3rem;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}
.success-stories .shout-out{
    aspect-ratio: 2 / 3;
}
.success-story{
    background-position: center;
    background-size: cover;
    border-radius: 5px;
    -webkit-transition: -webkit-filter 0.5s ease;
    transition: filter 0.5s ease;
}
.success-story:hover{
    -webkit-filter: none;
    filter:none;
}
.success-story > a{
    display: flex;
    padding: 3rem;
    color: var(--clr-white);
    text-decoration: none;
    text-shadow: 0 0 5px var(--clr-black);
    aspect-ratio: 2 / 3;
    align-items: flex-end;
    background-color: var(--clr-black-a-80);
    transition: background-color 0.5s ease;
    border-radius: 5px;
}
.success-story > a:hover{
    background-color:transparent;
}
.success-story > a > div{
    display:flex;
    flex-direction: column;
    gap:0.5rem;
}



/* ------------------------------------------------------------------------
SUCCESS PAGE
------------------------------------------------------------------------ */
.success-passport{
    background-color: var(--clr-gray-1);
    padding: 1rem;
    border-radius: 5px;
    text-align: center;
}
.success-thumbnail img{
    display: block;
    max-width:100%;
    height:auto;
    border-radius: 5px;
    margin:0 auto;
}
.success-passport .title{
    font-size:2.0rem;
    font-weight: 600;
    padding:0 0 0 0;
    margin-top:var(--grid-content-padding-top);
    /*border-top:solid 1px var(--clr-gray-1-60);*/
}
.success-passport .button{
    width:100%;
    margin:0.3rem 0 0 0;
}



/* ------------------------------------------------------------------------
HOME.PHP NIEUWSBERICHTEN PAGINA
------------------------------------------------------------------------ */
.newslib{
    display: grid;
    gap:3rem;
}
.news-excerpt{
    display:grid;
    position: relative;
    grid-template-areas:
        "thumbnail title date"
        "thumbnail text text"
        "thumbnail button button";
    grid-template-columns: min-content 1fr max-content;
    grid-template-rows: min-content min-content 1fr;
    gap:1rem 3rem;
    padding:3rem;
    border-radius: 5px;

    background-color: var(--clr-gray-1);
}
.news-excerpt .thumbnail{
    grid-area: thumbnail;
}
.news-excerpt .thumbnail img{
    display: block;
    max-width:200px;
    height:auto;
    border-radius: 5px;
    /*border:solid 1px var(--clr-gray-1-60);*/
}
.news-excerpt .thumbnail img.placeholder{
    border-radius:0;
}
.news-excerpt h2{
    grid-area: title;
    font-size: 1.8rem;
}
.news-excerpt .date{
    grid-area: date;
    font-size:1.4rem;
    font-weight: 600;
    color: var(--clr-1);
}
.news-excerpt .excerpt{
    grid-area: text;
    font-size: 1.4rem;
}
.news-excerpt .button{
    grid-area: button;
}
@media only screen and (max-width: 1200px) {
    .news-excerpt{
        display:grid;
        grid-template-areas:
            "thumbnail"
            "date"
            "title"
            "text"
            "button";
        grid-template-columns: 1fr;
        grid-template-rows: 1fr;
    }
    .news-excerpt .date{
        right:0; left:0;
        border-radius: 5px;
        text-align: center;
    }
    .news-excerpt .thumbnail{
        padding-top:2rem;
        /*aspect-ratio: 2/1;
        overflow: hidden;*/
    }
    .news-excerpt .thumbnail img{
        max-width: 400px;
        width:100%;
    }
}



/* ------------------------------------------------------------------------
NIEUWSBERICHT (POST)
------------------------------------------------------------------------ */
.featured-image{
    display: block;
    max-width:100%;
}
.featured-image img{
    max-width:100%;
    width:100%;
    height:auto;
}



/* ------------------------------------------------------------------------
VACATURES OVERZICHT
------------------------------------------------------------------------ */

.jobs{
    display: block;
}
.job{
    border-bottom:solid 1px var(--clr-gray-1-60);
    margin-top:0; padding-top:0;
}
.job a{
    display: block;
    width: 100%;
    text-decoration: none;
    color: var(--clr-1);
    padding:0.6rem 0;
}
.job a:hover{
    color: var(--clr-2);
}
.job a > div{
    display:grid;
    grid-template-areas:
        "col1 col2 col3";
    grid-template-columns: min-content 1fr min-content;
}
.job .fa-id-card{
    font-size:1.6rem;
    padding-top:3px;
    padding-right: 7px;
    grid-area: col1;
}
.job h2{
    font-size:1.6rem;
    font-weight: 400;
    grid-area: col2;
}
.job .fa-circle-right{
    font-size:1.6rem;
    padding-top:3px;
    grid-area: col3;
}


/* ------------------------------------------------------------------------
PREVIOUS / NEXT PAGE LINK STYLING
------------------------------------------------------------------------ */
.prevNext{
    display:flex;
    justify-content: space-between;
    gap:3rem;
}
.prevNext a{
    display: block;
    text-decoration:none;
    border-radius:5px;
    background-color: var(--clr-1);
    color:var(--clr-white) !important;
    padding: 1rem 2rem;
    margin-top:3rem;
    font-weight:600;
    transition: background-color 1s ease, box-shadow 1s ease;
}
.prevNext a.disabled{
    background-color: var(--clr-gray-1-60);
    color: var(--clr-1) !important;
}
.prevNext a[href]:hover{
    transition: background-color 0.5s ease;
    background-color: var(--clr-1-40);
}



/* ------------------------------------------------------------------------
BREADCRUMBS
------------------------------------------------------------------------ */
#bc{
    background-color:var(--clr-gray-1-60);
    padding:1rem 6rem;
}
.breadcrumbs{
    font-size: var(--fs-xs);
    list-style: none;
    display: flex;
}
.breadcrumbs li:not(:last-child)::after {
    content: '\00BB';
    padding:0 0.8rem;
}
.breadcrumbs a{
    text-decoration: none;
}
@media only screen and (max-width: 1200px) {
    #bc{
        padding:1rem var(--grid-padding-left);
    }
}



/* ------------------------------------------------------------------------
PAGINATION STYLING
------------------------------------------------------------------------ */
.pagination{
    display:flex;
    flex-wrap: nowrap;
    gap:1rem;
    justify-content: center;
}
.page-numbers{
    display: block;
    background-color:var(--clr-gray-1-60);
    padding: 1rem 2rem;
    text-decoration: none;
    color: var(--clr-1);
    border-radius: 5px;
    font-size:1.4rem;
}
a.page-numbers:hover{
    background-color:var(--clr-1);
    color: var(--clr-white);
}
.page-numbers.current{
    background-color: var(--clr-2);
    color: var(--clr-white);
}
/*.page-numbers.dots{}
.page-numbers.prev{}
.page-numbers.next{}*/
@media only screen and (max-width: 1200px) {
    .pagination{
        justify-content: space-between;
        align-items: stretch;
        flex-wrap: wrap;
    }
    .page-numbers{
        padding:1rem 1.6rem;
        font-size:1.2rem;
    }
}



/* ------------------------------------------------------------------------
YOUTUBE STYLING
------------------------------------------------------------------------ */
/*.wp-block-embed-youtube {}*/
.wp-block-embed__wrapper{
    overflow: hidden !important;
	position: relative !important;
	max-width: 100% !important;
	height: auto !important;
	padding-bottom: 56.25% !important;
}
.wp-block-embed-youtube iframe,
.wp-block-embed-youtube object,
.wp-block-embed-youtube embed,
.wp-block-embed-youtube video {
	position: absolute !important;
    width:100% !important;
    height:100% !important;
}
figcaption{
    text-align: center;
    background-color:var(--clr-gray-1-60);
    font-size: var(--fs-s);
    padding:1rem 1rem;
}

#mainOverlay {
    position: fixed; /* Sit on top of the page content */
    display: none; /* Hidden by default */
    width: 100%; /* Full width (cover the whole page) */
    height: 100%; /* Full height (cover the whole page) */
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0,0,0,0.7); /* Black background with opacity */
    z-index: 9999; /* Specify a stack order in case you're using a different order for other elements */
    cursor: pointer; /* Add a pointer on hover */
}
#mainOverlay .overlayContainer{
    display: grid;
    width: 100%; /* Full width (cover the whole page) */
    height: 100%; /* Full height (cover the whole page) */
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    align-items: center;
    justify-items: center;
}
#mainOverlay .youtubeFrame{
    position: absolute !important;
    width:66% !important;
    aspect-ratio: 16 / 9;
    max-height:90vh;
}



/* ------------------------------------------------------------------------
CUSTOM UL STYLING
------------------------------------------------------------------------ */
.checked-list{
    list-style: none;
}
.checked-list li:before{
    content: '✓';
    position: absolute;
    left:0;
    color: var(--clr-2);
}
.checked-list li{
    position: relative;
    padding-left:2rem;
}
ol.converted:not(.checked-list),
ul.converted:not(.checked-list){
    list-style-position: outside !important;
    margin-left:1.4rem;
}
ol.converted :not(:first-child),
ul.converted :not(:first-child) {
    margin-top:calc( var(--grid-content-padding-top) / 2);
}