@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Akaya+Kanadaka&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Dosis&display=swap');
:root {
    --border-style-1: 1px solid black;
    --hd-ft-bg-color: lavender;
    --hd-ft-color: black;
    --bg-color: lavenderblush;
    --mark-color: lightskyblue;
    --gap-style: 15px;
}
html {
    size: 100vw;
    font-size: 1rem;
    background-color: var(--bg-color);
}
body {
    margin: 0 3px;
}
header,
footer {
	font-family: "Dosis";
    text-transform: uppercase;
	color: var(--hd-ft-color);
	font-size: 0.75rem;
    font-weight: bold;
}
@media screen and (min-width: 576px) {
    header nav,
    footer {
        font-size: 1.2rem;
    }
 }

header {
    background-color: var(--hd-ft-bg-color);
    border-block-end: var(--border-style-1);
    padding-block-start: var(--gap-style);
}
header .logo {
    display: flex;
    inline-size: 300px;
    block-size: 150px;
    max-inline-size: 100%;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    border-radius: 50%;
    background-image: url('../img/logo-background.jpg');
    background-size: 100%;
    color: whitesmoke;
    text-decoration: none;
    font-size: 1.5rem;
}
header img {
    inline-size: 100%;
    block-size: 100px;
}
footer {
    block-size: 50px;
    background-color: var(--hd-ft-bg-color);
    border-block-start: var(--border-style-1);
    position: relative;
}
footer section {
    position: absolute;
    top: 50%; /* offset-block-start kent Chrome niet*/
    left: 50%; /* offset-inline-start werkt Chrome niet */
    margin-inline-end: -50%;
    transform: translate(-50%, -50%)
}
main {
    font-family: "Roboto Condensed";
}
hr {
    inline-size: 100%;
    margin: 0;
	border-block-start: var(--border-style-1);
    border-block-end: 0;
    background-color: transparent;
}
@media screen and (min-width: 768px) {
    header,
    footer,
    main {
        inline-size: 100%;
        display: grid;
        grid-template-columns: 1fr minmax(auto, 1024px) 1fr;
        align-items: center;
        justify-items: center;
    }
    header {
        grid-template-rows: auto 1px 100px;
        grid-template-areas:
        ". content ."
        "lijn lijn lijn"
        ". foto .";
    }
    footer {
        grid-template-areas:
            ". content .";
    }
    header .logo {
        grid-area: content;
        justify-self: start;
        margin: auto 0 var(--gap-style) var(--gap-style);
    }
    hr {
        grid-area: lijn;
    }
    header img {
        grid-area: foto;

    }
}
img {
    inline-size: 100%;
    block-size: auto;
    object-fit: cover;
}
nav {
    justify-self: end;
	box-sizing: content-box;
    justify-items: end;
	inline-size: 100%;
    margin: 0 5px;
	padding: 10px 0;
	background-color: transparent;
}
nav a {
    color: var(--hd-ft-color);
    text-align: center;
    text-decoration: none;
    padding: 3px;
	transition: all .5s ease-in-out .05s;
}
nav a:hover {
	background-color: var(--bg-color);
}
@media screen and (min-width: 768px) {
    nav {
        grid-area: content;
        inline-size: 50%;
    }
}
.menu {
    margin-inline-start: auto;
    margin-inline-end: 5px;
}
.menu td {
    text-align: center;
}
.menu td.hide {
    display: none;
}
.sub-menu,
.sub-menu ul {
    inline-size: 70px;
}
.sub-menu input {
    display: none;
}
.sub-menu label {
    background-color: transparent;
    color: var(--hd-ft-color);
    display: block;
    padding: 0;
    text-align: center;
}
.sub-menu label.markeer {
    background-color: var(--mark-color);
}
.sub-menu label::after {
    content: "\25BC";
}
.sub-menu ul {
    padding: 0;
    list-style: none;
    position: absolute;
    top: 185px; /* offset-block-start kent Chrome niet*/
    background-color: var(--hd-ft-bg-color);
    transform-origin: center -150px;
    transform: scaleY(0);
    transition: all .3s ease-out;
    border: 1px solid black;
}
.sub-menu a {
    display: block;
    padding: 5px;
    color: var(--hd-ft-color);
    text-decoration: none;
    transition: all .2s ease-in-out .05s;
}
.sub-menu a:hover {
    background-color: var(--bg-color) ;
}
.sub-menu input:checked ~ ul {
    transform: scaleY(1);
}
.sub-menu input:checked ~ label::after {
    content: "\25B2";
}
.markeer {
    background-color: var(--mark-color);
}

@media screen and (min-width: 576px) {
    .sub-menu,
    .sub-menu ul {
        inline-size: 110px;
    }
}
@media screen and (min-width: 768px) {
   .sub-menu ul {
        top: 100px;
    }
}
@media screen and (min-width: 992px) {
    .sub-menu,
    .sub-menu ul {
        inline-size: 120px;
    }
}