* {
    box-sizing: border-box;
}

body {
    font-family: din-2014, sans-serif;
    font-weight: 400;
    font-style: normal;
    padding: 2em;
    color: #222222;
    font-size: 12px;
}

#logo {
    display: flex;
    justify-content: center;
    margin: auto;
    padding: 5em 0;
    width: 35em;
    fill: #E34F26;
}

h1 {
    margin-block-start: 5rem;
    font-size: 42px;
    font-weight: 800;
    text-align: center;
}

h2 {
    margin: auto;
    text-align: center;
    width: 87%;
    font-size: 25px;
    padding-block-end: 6em;
}

h3 {
    padding-block-start: 30px;
    margin-top: 10px;
    margin-block-end: 0;
    font-size: 30px;
    text-transform: uppercase;
}

.topnav {
    text-align: center;
    font-size: 30px;
    font-weight: 800;
}

.topnav a {
    color: #222222;
    text-decoration: none;
    margin: 0 32px;
}

.topnav a.active {
    color: #E34F26;
}

.css:hover{
    color: #2AA2E0;
    transition: 0.2s;
}

.js:hover{
    color: #F0D81D;
    transition: 0.2s;
}

.csharp:hover{
    color: #642076;
    transition: 0.2s;
}

.vba:hover{
    color: #217145;
    transition: 0.2s;
}

.ps:hover{
    color: #0273B7;
    transition: 0.2s;
}

.games:hover{
    color: brown;
    transition: 0.2s;
}

.other:hover{
    color: rgb(71, 145, 68);
    transition: 0.2s;
}

.about{
    padding-block-start: 5em;
}

.vl{
    border-left: 150px solid #E34F26;
}

.articles {
    padding-inline-start: 10em;
}

.articles .article-content {
    margin: 15px 0 5em 50px;
    padding-block-end: 1em;
}

.articles a{
    text-decoration: none;
    color: #222222;
}

.articles .vl:hover{
background: #22222213;
}

.date {
    margin-block-start: 0;
    font-size: 15px;
    font-style: oblique;
    text-transform: uppercase;
}

.articlecontent {
    width: 85%;
    font-size: 20px;
}


/*footer*/
footer {
    text-align: center;
}

.contact {
    font-weight: 800;
    -webkit-padding-after: 1.5em;
    padding: 1.5em 0;
    font-size: 3em;
    text-transform: uppercase;
}

@media (min-width: 768px) and (max-width: 1024px) {
    .contact {
        font-size: 3em;
        -webkit-padding-after: 3.5em;
        padding-block-end: 3.5em;
    }
}



footer .mail {
    position: relative;
    padding: 0.625em;
    font-size: 2em;
    border: 0.1875em solid #222222;
    text-decoration: none;
    color: #222222;
}

footer a:hover {
    text-decoration: underline;
}


.info {
    margin: 0;
    padding-block-start: 4em;
    font-size: 1.5rem;
    font-style: oblique;
}

@media (min-width: 768px) and (max-width: 1024px) {
    .info {
        font-size: 1.5rem;
    }
}

.social {
    justify-content: center;
    display: flex;
}

.social a {
    padding: 0;
    margin: 2.667em;
}

.social svg {
    width: 5em;
}

.social svg:hover {
    fill: #0271AE;
    transition: 0.3s;
}