@import url("menu.css");

*,
:before,
:after {
    box-sizing: border-box;
}

*:focus-visible {
    outline-color: var(--focus-outline-color);
    outline-offset: var(--focus-outline-offset);
    outline-style: var(--focus-outline-style);
    outline-width: var(--focus-outline-width);
}

html,
body {
    margin: 0;
}

body {
    font-family: "Noto Sans", sans-serif;
    font-weight: normal;
    font-size: 16px;
    line-height: 1.6;
    -webkit-text-size-adjust: 100%;
    background: var(--light-grey);
    background-image: url(images/bgimg.png);
    background-position: center 210px;
    background-repeat: no-repeat;
}

body.landingspagina {
    background-image: url(images/bgimglp.png);
    background-position: center 120px;
    background-repeat: no-repeat;
}

#aspnetForm {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 100vh;
}

h1,
h2,
h3,
h4 {
    font-family: "Noto Sans", sans-serif;
    margin: 0;
    line-height: 1.2;
    font-weight: 700;
}

h1,
.h1-style {
    font-size: clamp(1.6rem, 0.76rem + 2.24vw, 2.3rem); 
    color: var(--default-black);
    margin-bottom: 48px;
}

h2,
.h2-style {
    font-size: clamp(1.2625rem, 0.8575rem + 1.08vw, 1.6rem);
    color: var(--default-black);
    margin-bottom: 48px;
}

h3 {
    font-size: 20px;
    color: var(--default-black);
}

h4, .h4-style {
    font-size: 18px;
}

.belangrijke-cijfers {
    font-size: clamp(1.875rem, 0.525rem + 3.6vw, 3rem);
    font-weight: 500;
}


.tile-section-text,
.text-normal,
p {
    font-size: 16px;
    color: var(--default-black);
    padding: 0;
    font-weight: 400;
}

#ctl00_QsPH_hoofdstukken_tileset .tile a {
    text-decoration: none !important;
}

.b_btn {
    font-size: 16px;
    padding: 12px 18px;
    display: block;
    color: var(--default-white);
    background: var(--primary-green-color);
    border: none;
    height: fit-content;
    cursor: pointer;
    border-radius: 5px;
    width: fit-content;
    text-decoration: none !important;
    font-weight: 400;
}

.b_btn:hover {
    background: var(--hover-primary);
    color: #FFF;
}

.b_btn:focus-visible {
    clip-path: unset;
    outline-color: var(--focus-outline-color);
    outline-offset: -6px;
}

.a-fa.b_btn:focus-within::after,
.a-fa.b_btn:hover::after{
    margin-left: 14px;
}

.a-fa.b_btn:focus-within,
.a-fa.b_btn:hover {
    padding-right: 14px;
}


.loginfield {
    display: flex;
    flex-direction: column;
    gap: 12px;
}


/* Hero section */

.introtext {
    padding: 48px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    max-width: 610px;
    width: 100%;
    background: var(--default-white);
    z-index: 1;
    position: relative;
    box-shadow: 0 4px 15px 0 rgba(40, 44, 53, 0.06);
}

.introtext h1,
.introtext p {
    margin: 0;
}

.introtext p {
    font-size: 18px;
}

.linkbar {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.linkbar .a-fa:not(.b_btn) {
    color: var(--primary-green-color);
}

.linkbar .a-fa:hover:not(.b_btn) {
    text-decoration: none;
}

.linkbar .a-fa::after {
    content: "\f054";
    font-weight: 700;
}
    
.hero-section.grid {
    padding-top: 63px;
    padding-bottom: 63px;
    margin-bottom: 50px;
}

.backgroundimghero { 
    background-image: url(images/banner.png);
    background-position: center;
    background-repeat: no-repeat;
}

/* Belangrijke cijfers section */
.grid.belangrijke-cijfers {
    max-width: 1280px;
    padding: 24px 15px 48px;
}

.tileset h2 {
    text-align: center;
}

.belangrijke-cijfers .tileset--content--items {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    justify-content: space-between;
    grid-gap: 30px;
    width: 100%;
}

.belangrijke-cijfers .tile{
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    height: 100%;
    background: var(--default-white);
    box-shadow: 0 4px 15px 0 rgba(40, 44, 53, 0.06);
}

/* Hoofdstukken section */
.grid.hoofdstukken {
    max-width: 1280px;
    padding: 24px 15px 48px;
}

.hoofdstukken .tileset--content--items {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    justify-content: space-between;
    grid-gap: 30px;
    width: 100%;
}

.hoofdstukken .tile{
    padding: 24px;
    margin-top: 5px;
    border-left: solid 5px var(--primary-green-color);
    background: var(--default-white);
    box-shadow: 0 4px 15px 0 rgba(40, 44, 53, 0.06);
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 24px;
    height: 100%;
}

.hoofdstukken a:not(.b_btn){
    display: flex;
    flex-direction: column;
    gap: 12px;
    position: relative;
    color: var(--default-black);
    text-decoration: none;
}

.hoofdstukken .tile::after {
    font-size: 15px;
    font-family: "Font Awesome 6 Pro";
    font-weight: 700;
    content: "\f054";
    display: flex;
    position: relative;
    width: 24px;
    height: 24px;
    color: var(--default-white);
    background: var(--primary-green-color);
    border-radius: 3px;
    align-items: center;
    justify-content: center;
    margin-left: auto;
    margin-top: auto;
}

.hoofdstukken .tile:hover{
    margin-top: 0;
    margin-bottom: 5px;
}

.hoofdstukken .readmore {
    margin-top: 48px;
}

.hoofdstukken .b_btn {
    margin-top: 48px;
}

.hoofdstukken .a-fa::after{
    content: "\f054";
}


/* beheer section */
.beheerheader,
.grid.beheer{
    display: none;
}

.introbeheer p {
    margin: 0;
}

.beheerheader h2{
    text-align: center;
}

.role_SysAdmin .grid.beheer,
.role_SysAdmin .beheerheader {
    display: block;
}

.introbeheer {
    padding: 48px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    max-width: 610px;
    width: 100%;
    background: var(--default-white);
    position: relative;
    box-shadow: 0 4px 15px 0 rgba(40, 44, 53, 0.06);
}

.introbeheer .linkbar {
    display: flex;
    flex-direction: row;
    gap: unset;
    justify-content: space-between;
    align-items: center;
}

.introbeheer .a-fa {
    color: var(--primary-green-color);
}

.introbeheer .a-fa:hover,
.introbeheer .a-fa:focus-within{
    text-decoration: none;
}

.introbeheer .b_btn {
    color: var(--default-white);
}


.introbeheer .a-fa::after{
    content: "\f054";
}

.grid.beheer {
    max-width: 1250px;
    padding: 48px;
    background-image: url(images/beheer.jpg);
    background-size: cover;
}


/* Publicaties */
#ctl00_QsPH_publicaties_tileset {
    .tileset--content--items{
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        justify-content: space-between;
        grid-gap: 30px;
        width: 100%;
    }

    .tile {
        margin-top: 5px;
        background: var(--default-white);
        height: 100%;
        box-shadow: 0 4px 15px 0 rgba(40, 44, 53, 0.06);
    }
    
    a {
        text-decoration: none;
        color: var(--default-black);
        height: 100%;
        display: flex;
        flex-direction: column;
    }

    .tile-section-icon{
        height: 205px;
    }

    .tile-section-icon img{
        height: 100%;
        width: 100%;
        object-fit: cover;
    }

    .tile .text-card {
        display: flex;
        flex-direction: column;
        gap: 12px;
        padding: 24px;
        flex: 1;
    }

    .datumtag {
        border-left: solid 4px var(--secondary-blue-color);
        line-height: 27.2px;
        padding-left: 16px;
    }
}

#ctl00_QsPH_publicaties_tileset .tile:focus-within,
#ctl00_QsPH_publicaties_tileset .tile:hover {
    margin-top: 0;
    margin-bottom: 5px;
    color: var(--default-black);
}

.grid.news  .b_btn{
    margin-top: 48px;
    margin-bottom: 80px;
}

.grid.news  .b_btn::after {
    content: "\f054";
}


/* Documents page - Start */
.b_module-wrapper {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

#nav_module {
    width: 390px;
    
    ul {
        padding: 0;
        margin: 0;
        list-style-type: none;
    }
}

#nav_module li {
    margin-bottom: 8px;
}

#nav_module a {
    text-decoration: none;
    font-weight: 500;
    color: var(--default-black);
    line-height: 24px;
}

#nav_module .active a {
    display: inline-block;
    font-weight: 600;
    padding-left: 8px;
    border-left: 5px solid var(--primary-green-color);
    word-break: break-word;
    color: var(--default-black);
}

.b_module-items {
    max-width: 823px;
    
    ul li {
        margin-bottom: 30px;
        background: #ffffff;
    }
}

.fa-li {
    left: unset;
    position: relative;
    color: var(--primary-green-color);
    width: 24px;
    height: 24px;
    text-align: left;
}

.fa-chevron-right:before{
    font-weight: 700;
}

.ballroomcategories {
    font-weight: 700;
    color: var(--primary-green-color);
}

.documentlistitem__image,
.b_meta {
    display: none;
}

.document {
    padding: 24px;
    background: var(--default-white);
    box-shadow: 0 4px 15px 0 rgba(40, 44, 53, 0.06);
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.document h2{
    font-size: 20px;
    font-weight: 700;
    line-height: 120%;
    margin: 0;
}

.document p {
    margin: 0;
}

.document a {
    color: var(--primary-green-color);
    display: inline-block;
}

.document a:hover,
.document a:focus-within {
    text-decoration: none;
}

.document a::before{
    font-size: 15px;
    font-family: "Font Awesome 6 Pro";
    font-weight: 700;
    content: "\f019";
    display: inline-block;
    margin-right: 8px;
}

.sub-list {
    margin-top: 8px !important;
    padding-left: 25px !important;
}
/* Documents page - end */


/* Custom pages - Start */
#custompagecontent {
    h1 {
        text-align: center;
        margin: 0;
    }

    p {
        margin-top: 0;
        font-size: 18px;
        
        a:not(.b_btn) {
            color: var(--primary-green-color);
        }
        a:hover,
        a:focus-within {
            text-decoration: none;
        }
    }

    h2{
        margin-bottom: 24px;
    }
    .custom-page-content {
        padding: 48px 0;
    }

    .custom-page-content:not(:last-of-type) {
        border-bottom: solid 2px var(--secondary-blue-color);
    }
}
/* Custom pages - End */

/* Contact page - start */
.subscribe{
    display: none;
}

.contactinput input:not(.b_btn) {
    padding-left: 5px;
    min-width: 500px;
    width: 50%;
    height: 34px;
    font-size: 16px;
}

.contactform .contactinput {
    margin-bottom: 10px;
}

.contactinput .b_btn{
    background: var(--primary-green-color);
    color: var(--default-white);
    border: none;
    cursor: pointer;
}

textarea {
    font-family: inherit;
    font-size: 16px;
    width: 50%;
    min-width: 500px;
    padding: 5px;
}

.error {
    display: block;
    font-size: 16px;
    margin-bottom: 8px;
    color: var(--error-color);
}
/* Contactpage end */

@media screen and (max-width: 1000px) {
    #ctl00_QsPH_publicaties_tileset .tileset--content--items,
    .hoofdstukken .tileset--content--items,
    .belangrijke-cijfers .tileset--content--items {
        grid-template-columns: 1fr 1fr;
    }

}
@media screen and (max-width: 800px) {
    .hero-section.grid {
        padding: 0;
        height: unset;
    }
    .introtext {
        padding: 30px;
        max-width: 100%;
    }
    .hero-section::after {
        display: none;
    }

}


@media screen and (max-width: 600px) {
    #ctl00_QsPH_publicaties_tileset .tileset--content--items,
    .hoofdstukken .tileset--content--items,
    .belangrijke-cijfers .tileset--content--items {
        grid-template-columns: 1fr;
    }
    #content, .grid,
    .grid.belangrijke-cijfers,
    .grid.hoofdstukken {
        padding: 15px;
    }
    
    .grid.belangrijke-cijfers {
        padding: 30px 15px 15px;
    }

    .hoofdstukken .b_btn {
        margin-top: 30px;
    }
    .grid.news .b_btn {
        margin-top: 30px;
        margin-bottom: 50px;
    }

    h2,
    .h2-style {
        margin-bottom: 30px;
    }

}

@media screen and (max-width: 530px) {
    
    textarea,
    .contactinput input:not(.b_btn) {
        min-width: unset !important;
        width: 100%;
    }

    

}