﻿:root {
    --light-primary-color: color-mix(in srgb, var(--primary-color) 40%, white);
}

.progressbar {
    counter-reset: step;
    width: 100%;
    margin: auto;
    /*height: 100px;*/
    padding: 0px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    vertical-align: middle;
}

    .progressbar li {
        list-style-type: none;
        width: 25%;
        float: left;
        font-size: 0.9em;
        /*font-weight: 300;*/
        position: relative;
        text-align: center;
        text-transform: uppercase;
        color: var(--light-primary-color);
    }

        .progressbar li:before {
            width: 30px;
            height: 30px;
            content: '';
            counter-increment: step;
            line-height: 30px;
            border: 2px solid var(--light-primary-color);
            display: block;
            text-align: center;
            margin: 0 auto 10px auto;
            border-radius: 50%;
            background-color: var(--light-primary-color);
            position: relative;
            z-index: 999;
            cursor: pointer;
        }

        .progressbar li:after {
            width: 100%;
            height: 2px;
            content: '';
            position: absolute;
            background-color: var(--light-primary-color);
            top: 15px;
            left: -50%;
            z-index: 800;
        }

        .progressbar li:first-child:after {
            content: none;
        }

        .progressbar li.complete {
            color: var(--primary-color);
        }

            .progressbar li.complete:before {
                border-color: var(--primary-color);
                background-color: var(--primary-color);
            }

        .progressbar li.active {
            color: var(--primary-color);
        }

        .progressbar li.active:before {
            border-color: var(--primary-color);
            background-color: #fff;
        }

            .progressbar li.complete + li:after {
                background-color: var(--primary-color);
            }


.progressbar-vertical {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 20%;
    height: 100%;
    margin: 0px auto;
}


    .progressbar-vertical li {
        list-style-type: none;
        width: 100%;
        height: 25%;
        font-size: 0.9em;
        /*font-weight: 300;*/
        position: relative;
        text-align: center;
        text-transform: uppercase;
        color: #6d6d6d;
        padding: 20px 0px;
    }

        .progressbar-vertical li:after {
            height: 100%;
            width: 2px;
            content: '';
            position: absolute;
            background-color: var(--light-primary-color);
            top: -50%;
            left: 50%;
            z-index: 800;
        }