/*main styles*/
:root {
    --base_size: 16px;
    /* base colors */
    --black: #171923;
    --white: #FFFFFF;
    --gray: #BABABA;
    --lightgray: #f7f7f7;
    --red: #CE2B37;
    --green: #009246;
    --blue: #2B8ACE;
    --yellow: #D8D125;
    --yellowlight: #f8f26f;
}
html {
    scroll-behavior: smooth;
    font-size: var(--base_size);
}

*sfsdfs {
    outline: 1px solid #009246!important;
}

body {
    color: var(--black);
    font-family: "League Spartan", sans-serif;
    font-optical-sizing: auto;
    font-size: var(--base_size);
    font-weight: 400;
    font-style: normal;
    background-color: var(--bgwhite);
}
h1, .h1 {
    font-size: 3em;
    line-height: 1em;
    font-weight: 600;
}
h1 strong, .h1 strong {
    font-weight: 700;
}
h1 span, .h1 span {
    color: var(--red);
}
h2, .h2 {
    font-size: 2.4em;
    font-weight: 600;
}
h2 span, .h2 span {
    padding: 0.2em 0.5em;
    background-color: var(--yellowlight);
}
h2 strong, .h2 strong {
    font-weight: 700;
}
h3, .h3 {
    font-size: 2em;
    font-weight: 600;
}
h4, .h4 {
    font-size: 1.6em;
    font-weight: 600;
}
a {
    text-decoration: none;
    color: var(--blue);
}
#progetti,
#servizi,
#sviluppo,
#ecommerce,
#marketing,
#supporto,
#esperienza,
#contatti
{
    scroll-behavior: smooth;
    scroll-margin-top: 8em;
}
img {
    max-width: 100%;
    height: auto;
}
p.bigger {
    font-size: 1.2em;
    font-width: 500;
}

.container, .container-fluid {
    overflow: hidden;
}
.text-justify {
    text-align: justify;
}

.pr-3 {
    padding-right: 3em;
}
.mt-8 { margin-top: 8em; }
.mb-8 { margin-bottom: 8em; }

.rounded { border-radius: 1rem!important; }
.rounded-2 { border-radius: 2rem!important; }
.rounded-3 { border-radius: 3rem!important; }
.rounded-4 { border-radius: 4rem!important; }
.rounded-5 { border-radius: 5rem!important; }

/* elements */
.blue-list {
    margin-top: 7em;
    margin-bottom: 5em;
    max-width: 35em;
    list-style: none;
}
.blue-list li {
    margin-left: 5em;
    margin-bottom: 4em;
}
.blue-list li h2 {
    margin-bottom: 0.5em;
}
.blue-list li h2::before {
    content: "";
    display: block;
    position: absolute;
    width: 1.2em;
    height: 0.2em;
    margin-left: -2em;
    margin-top: 0.4em;
    background-color: var(--white);
    border-radius: 0.3em;
}
.cards {
    border: 3px solid var(--gray);
}
.cards .icons {
    width: 4em;
    height: 4em;
    margin-bottom: 1.5em;
}
.icon-tech {
    list-style: none;
}
.icon-tech li {
    width: 4em;
    height: 4em;
    display: inline-block;
    margin: 0 1em 1em 0px;
}
.contact-list {
    list-style: none;
}
.contact-list li {
    display: inline-block;
    border: 3px solid var(--blue);
    padding: 1em 2em 1em 3.5em;
    margin-right: 2em;
    margin-bottom: 1em;
    border-radius: 1em;
    min-width: 14em;
}
.contact-list a {
    text-decoration: none;
    color: var(--black);
}
.contact-list li a img {
    display: inline-block;
    position: absolute;
    margin-left: -2.5em;
}
.border-red {
    border-color: var(--red)!important;
}

.footer {
    background-color: var(--black);
    color: var(--white);
    border-top: 0px solid var(--red);
    font-size: 0.8em;
    /*border-radius: 2em 2em 0em 0em;*/
}
.footer .logo {
    width: 11em;
    height: 3em;
}
.footer .h5 {
    color: var(--yellow);
}
.footer a {
    color: var(--white);
}
.footer ul {
    list-style: none;
    margin-left: -1em;
}
.footer ul li {
    padding-bottom: 1em;
}
.footer ul li::before {
    content: "";
    position: absolute;
    display: block;
    width: 0.75em;
    height: 0.15em;
    margin-left: -1.5em;
    margin-top: 0.5em;
    background-color: var(--yellow);
    border-radius: 0.1em;
}
.footer .copyrights {
    color: var(--gray);
    letter-spacing: 1px;
}

/* backgrounds */
.color-white { color: var(--white); }
.background-blue {
    background-color: var(--blue);
    background-image: url("/img/bg-blue-01.svg");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center; 
}
.background-lightgray { background-color: var(--lightgray); }

.background-img-01 {
    background-image: url("/img/img-02.jpg");
    background-position: top right;
    background-repeat: no-repeat;
    background-size: cover;
}
/* diveders */
.diver-1 {
    display: inline-block;
    background-color: var(--red);
    width: 3.2em;
    height: 0.5em;
    border-radius: 0.5em;
}
.diver-2 {
    display: inline-block;
    width: 2em;
    height: 0.3em;
    border-radius: 0.3em;
}
.diver-red { background-color: var(--red); }
.diver-blue { background-color: var(--blue); }
.diver-green { background-color: var(--green); }
/*menu*/
.navbar {
    margin-bottom: 3.5em;
}
.navbar-expand-lg .navbar-nav .nav-link {
    padding-left: 0em;
    padding-right: 0em;
    margin-left: 2em;
    line-height: 1.5em;
    border-bottom: 2px solid var(--white);
}
.navbar-expand-lg .navbar-nav .nav-link:hover {
    border-bottom: 2px solid var(--red);
}
.navbar-toggler-icon {
    cursor: pointer;
}
.offcanvas {
    background-color: var(--black)!important;
}
.offcanvas .logo {
    width: 8em;
    height: 3em;
}
.offcanvas .popup-menu {
    margin-top: 1em;
    list-style: none;
}
.offcanvas .popup-menu a {
    color: var(--white);
}
.offcanvas .popup-menu li::before {
    content: "";
    display: inline-block;
    position: relative;
    top: -0.2em;
    margin-left: -1.5em;
    margin-right: 1em;
    width: 0.75em;
    height: 0.15em;
    background-color: var(--red);
    border-radius: 0.1em;
}
.offcanvas .popup-contact {
    margin-top: 2em;
    margin-left: 0;
    padding-left: 0;
    list-style: none;
}
.offcanvas .popup-contact li img {
    width: 1.5em;
    height: 1.5em;
    display: inline-block;
    float: left;
    margin-right: 1em;
}
.offcanvas .popup-contact li a {
    display: inline-block;
    width: 100%;
    color: var(--white);
    border: 2px solid var(--white);
    padding: 1em;
    border-radius: 0.5em;
    margin-bottom: 1em;
}
.offcanvas .popup-contact li a .h4 {
    font-size: 1.2em;
    padding-left: 3em;
}
.offcanvas .popup-contact li p {
    padding-left: 3.5em;
}
.offcanvas .popup-footer {
    margin-top: 2em;
    padding-top: 1em;
    font-size: 1em;
    font-weight: 400;
    color: var(--gray);
}
/* projects logo */
.projects {
    display: flex;
    flex-wrap: wrap;
    justify-content: start;
    gap: 1.5em;
    align-items: center;
}
.project {
    max-width: 14em;
    border: 1px solid var(--lightgray);
    box-shadow: 7px 7px 7px var(--lightgray);
    border-radius: 1em;
}
.project a {
    display: inline-block;
    vertical-align: middle;
    text-align: center;
    padding: 1em 2em;
    width: 100%;
}
.project:last-child {
    border: 1px solid var(--red);
    background-color: var(--red);
}
.project:last-child a {
    color: var(--white);
}
.blog {

}

.tags {
    display: flex;
    align-content: start;
    list-style: none;
    margin-left: 0px;
    padding-left: 0px;
}
.tags li {
    color:  var(--black);
    background-color: var(--white);
    line-height: 1em;
    padding: 0.5em 1em;
    margin-right: 0.5em;
    border-radius: 1em;
    border: 1px solid var(--lightgray);
}
.tags .date {
    padding: 0.5em 0em;
    color: var(--gray);
    background-color: transparent;
    border: none;
}
.tags .author {
    margin-left: 64px;
    background-color: transparent;
    border: none;
}
.tags .author:before {
    content: "";
    display: block;
    position: absolute;
    background-image: url("/post/avatar/oleksandr.jpg");
    background-size: cover;
    background-position: center center;
    border-radius: 24px;
    width: 48px;
    height: 48px;
    margin-left: -64px;
    margin-top: -16px;
}
.post-content {

}
.post-content h1, .post-content h2, .post-content h3 {
    margin-bottom: 0.5em;
}
.post-content h4 {
    margin-bottom: 0.75em;
}
.post-content h1 span, .post-content h2 span, .post-content h3 span {
    padding: 0.25em 0.35em 0.1em 0.35em;
    background-color: var(--yellowlight);
    font-weight: 400;
}
.post-content h2 {
    margin-bottom: 0.5em;
}
.post-content h3 {
    margin-bottom: 0.5em;
}
.post-content p {
    line-height: 1.75em;
    margin-bottom: 2em;
}
.post-content ul {
    list-style: none;
}
.post-content ul li {
    margin-bottom: 1em;
}
.post-content ul li:before {
    content: "";
    display: block;
    position: absolute;
    width: 1em;
    height: 0.2em;
    margin-left: -2em;
    margin-top: 0.5em;
    background-color: var(--blue);
    border-radius: 0.3em;
}

@media (max-width: 576px) {

}/*end min-width: 576px*/

@media (max-width: 768px) {
    h1, .h1 {
        font-size: 2.4em;
    }
    h2, .h2 {
        font-size: 2em;
        font-weight: 600;
    }
    .contattaci h2 {
        font-size: 1.6em;
    }
    .pr-3 {
        padding-right: 1em;
    }
    .navbar {
        margin-bottom: 1em;
    }
    .mb-8  {
        margin-bottom: 2em;
    }
    .mt-8  {
        margin-top: 2em;
    }
    .blue-list {
        margin-top: 5em;
        margin-bottom: 5em;
        list-style: none;
        padding-left: 0px;
    }
    .blue-list li {
        margin-left: 3em;
        margin-bottom: 3em;
    }
    .blue-list li h2::before {
        width: 0.75em;
        margin-left: -1.4em;
    }
    .icon-tech li {
        width: 2.5em;
        height: 2.5em;
        margin: 0 0.5em 0.5em 0.5em;
    }
    .cards {
        border-width: 2px;
        padding: 1.5em!important;
    }
    .contact-list li {
        padding: 1em 2em 0.5em 4em;
        margin-bottom: 2em;
        min-width: 90%;
    }
    .project {
        max-width: 45%;
        gap: 1em;
    }
    .project a {
        padding: 0.5em 1em;
    }
}/*end min-width: 768px*/

@media (max-width: 992px) {

}/*end min-width: 992px*/

@media (max-width: 1200px) {

}/*end min-width: 1300px*/

@media (max-width: 1400px) {

} /*end min-width: 1400px*/