.proportions-box-square {
    position: relative;
    padding: 100% 0 0 !important;
    height: 0;
}

.proportions-box-content {
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    position: absolute;
}

.background-cover {
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.background-left-top {
    background-position: left top;
}

.background-left-center {
    background-position: left center;
}

.background-left-bottom {
    background-position: left bottom;
}

.background-right-top {
    background-position: right top;
}

.background-right-center {
    background-position: right center;
}

.background-right-bottom {
    background-position: right bottom;
}

.background-center-top {
    background-position: center top;
}

.background-center-center {
    background-position: center center;
}

.background-center-bottom {
    background-position: center bottom;
}

.border-width-1 {
    border-width: 1px !important;
}

.border-width-2 {
    border-width: 2px !important;
}

.border-width-3 {
    border-width: 3px !important;
}

.border-width-4 {
    border-width: 4px !important;
}

.border-width-6 {
    border-width: 6px !important;
}

.border-width-8 {
    border-width: 8px !important;
}

.border-width-12 {
    border-width: 12px !important;
}

.border-width-16 {
    border-width: 16px !important;
}

.border-width-24 {
    border-width: 24px !important;
}

.image-fit {
    object-fit: contain;
    object-position: center center;
}

.image-fit-left-top {
    object-position: left top;
}

.image-fit-left-center {
    object-position: left center;
}

.image-fit-left-bottom {
    object-position: left bottom;
}

.image-fit-right-top {
    object-position: right top;
}

.image-fit-right-center {
    object-position: right center;
}

.image-fit-right-bottom {
    object-position: right bottom;
}

.image-fit-center-top {
    object-position: center top;
}

.image-fit-center-center {
    object-position: center center;
}

.image-fit-center-bottom {
    object-position: center bottom;
}

.transition {
    transition: all 0.25s ease-in;
}

.transition-slow {
    transition: all 0.5s ease-in;
}

.transition-very-slow {
    transition: all 1s ease-in;
}

.line-height-1 {
    line-height: 1 !important;
}

.opacity-100 {
    opacity: 1 !important;
}

.opacity-85 {
    opacity: 0.85 !important;
}

.opacity-75 {
    opacity: 0.75 !important;
}

.opacity-50 {
    opacity: 0.50 !important;
}

.opacity-25 {
    opacity: 0.25 !important;
}

.opacity-0 {
    opacity: 0 !important;
}

@media (min-width:1200px) {
    .body-sol-dev {
        font-size: 25px;
        font-weight: bold;
        display: grid;
        grid-template-columns: 8% 20% 10% 2% 20% [titlehoriz-start] 10% 20% 10% [titlehoriz-end];
        grid-template-rows: 65px 100px [title-start] 100px [title-end] 100px 100px 100px 47px 0px 40px 100px 100px 214px 40px 100px 100px 214px 40px 100px 100px 214px 40px 100px 100px 100px 40px 40px;
        grid-template-areas: '. . . . . . . .' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2' 'lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt' '. busanalysttitle busanalysttitle busanalysttitle busanalysttitle . . .' '. busanalystimg busanalystimg . busanalystblurb busanalystblurb busanalystblurb .' '. . . . busanalystblurb busanalystblurb busanalystblurb .' '. . . . busanalystblurb busanalystblurb busanalystblurb .' '. databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle .' '. databasedevimg databasedevimg . databasedevblurb databasedevblurb databasedevblurb .' '. . . . databasedevblurb databasedevblurb databasedevblurb .' '. . . . databasedevblurb databasedevblurb databasedevblurb .' '. softwaredevtitle softwaredevtitle softwaredevtitle softwaredevtitle . . .' '. softwaredevimg softwaredevimg . softwaredevblurb softwaredevblurb softwaredevblurb .' '. . . . softwaredevblurb softwaredevblurb softwaredevblurb .' '. . . . softwaredevblurb softwaredevblurb softwaredevblurb .' '. etlprocesstitle etlprocesstitle etlprocesstitle etlprocesstitle . . .' '. etlprocessimg etlprocessimg . etlprocessblurb etlprocessblurb etlprocessblurb .' '. . . . etlprocessblurb etlprocessblurb etlprocessblurb .' '. . . . etlprocessblurb etlprocessblurb etlprocessblurb .' '. copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt . . .' '. . . . . . . .';
    }
}

@media (min-width:992px) and (max-width:1199px) {
    .body-sol-dev {
        font-size: 25px;
        font-weight: bold;
        display: grid;
        grid-template-columns: 8% 20% 10% 2% 20% [titlehoriz-start] 10% 20% 10% [titlehoriz-end];
        grid-template-rows: 65px 100px [title-start] 100px [title-end] 100px 100px 100px 47px 0px 40px 100px 100px 90px 40px 100px 100px 90px 40px 100px 100px 90px 40px 100px 100px 100px 40px 40px;
        grid-template-areas: '. . . . . . . .' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2' 'lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt' '. busanalysttitle busanalysttitle busanalysttitle busanalysttitle . . .' '. busanalystimg busanalystimg . busanalystblurb busanalystblurb busanalystblurb .' '. . . . busanalystblurb busanalystblurb busanalystblurb .' '. . . . busanalystblurb busanalystblurb busanalystblurb .' '. databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle .' '. databasedevimg databasedevimg . databasedevblurb databasedevblurb databasedevblurb .' '. . . . databasedevblurb databasedevblurb databasedevblurb .' '. . . . databasedevblurb databasedevblurb databasedevblurb .' '. softwaredevtitle softwaredevtitle softwaredevtitle softwaredevtitle . . .' '. softwaredevimg softwaredevimg . softwaredevblurb softwaredevblurb softwaredevblurb .' '. . . . softwaredevblurb softwaredevblurb softwaredevblurb .' '. . . . softwaredevblurb softwaredevblurb softwaredevblurb .' '. etlprocesstitle etlprocesstitle etlprocesstitle etlprocesstitle . . .' '. etlprocessimg etlprocessimg . etlprocessblurb etlprocessblurb etlprocessblurb .' '. . . . etlprocessblurb etlprocessblurb etlprocessblurb .' '. . . . etlprocessblurb etlprocessblurb etlprocessblurb .' '. copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt . . .' '. . . . . . . .';
    }
}

@media (min-width:768px) and (max-width:991px) {
    .body-sol-dev {
        font-size: 25px;
        font-weight: bold;
        display: grid;
        grid-template-columns: 8% 20% 10% 6% 20% [titlehoriz-start] 10% 20% 6% [titlehoriz-end];
        grid-template-rows: 65px 100px [title-start] 100px [title-end] 100px 100px 100px 47px 0px 40px 100px 100px 150px 40px 100px 100px 190px 40px 100px 100px 170px 40px 100px 100px 100px 40px 40px;
        grid-template-areas: '. . . . . . . .' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2' 'lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt' '. busanalysttitle busanalysttitle busanalysttitle busanalysttitle . . .' '. busanalystimg busanalystimg . busanalystblurb busanalystblurb busanalystblurb .' '. . . . busanalystblurb busanalystblurb busanalystblurb .' '. . . . busanalystblurb busanalystblurb busanalystblurb .' '. databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle .' '. databasedevimg databasedevimg . databasedevblurb databasedevblurb databasedevblurb .' '. . . . databasedevblurb databasedevblurb databasedevblurb .' '. . . . databasedevblurb databasedevblurb databasedevblurb .' '. softwaredevtitle softwaredevtitle softwaredevtitle softwaredevtitle . . .' '. softwaredevimg softwaredevimg . softwaredevblurb softwaredevblurb softwaredevblurb .' '. . . . softwaredevblurb softwaredevblurb softwaredevblurb .' '. . . . softwaredevblurb softwaredevblurb softwaredevblurb .' '. etlprocesstitle etlprocesstitle etlprocesstitle etlprocesstitle . . .' '. etlprocessimg etlprocessimg . etlprocessblurb etlprocessblurb etlprocessblurb .' '. . . . etlprocessblurb etlprocessblurb etlprocessblurb .' '. . . . etlprocessblurb etlprocessblurb etlprocessblurb .' '. copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt . . .' '. . . . . . . .';
    }
}

@media (min-width:576px) and (max-width:767px) {
    .body-sol-dev {
        font-size: 25px;
        font-weight: bold;
        display: grid;
        grid-template-columns: 8% 20% 10% 2% 20% [titlehoriz-start] 10% 20% 10% [titlehoriz-end];
        grid-template-rows: 65px 100px [title-start] 100px [title-end] 100px 100px 100px 47px 0px 40px 100px 100px 250px 40px 100px 100px 291px 40px 100px 100px 226px 40px 100px 100px 100px 104px 40px;
        grid-template-areas: '. . . . . . . .' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2' 'lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt' '. busanalysttitle busanalysttitle busanalysttitle busanalysttitle . . .' '. busanalystimg busanalystimg . . . . .' '. . . . . . . .' '. busanalystblurb busanalystblurb busanalystblurb busanalystblurb busanalystblurb busanalystblurb .' '. databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle .' '. databasedevimg databasedevimg . . . . .' '. . . . . . . .' '. databasedevblurb databasedevblurb databasedevblurb databasedevblurb databasedevblurb databasedevblurb .' '. softwaredevtitle softwaredevtitle softwaredevtitle softwaredevtitle . . .' '. softwaredevimg softwaredevimg . . . . .' '. . . . . . . .' '. softwaredevblurb softwaredevblurb softwaredevblurb softwaredevblurb softwaredevblurb softwaredevblurb .' '. etlprocesstitle etlprocesstitle etlprocesstitle etlprocesstitle . . .' '. etlprocessimg etlprocessimg . . . . .' '. . . . . . . .' '. etlprocessblurb etlprocessblurb etlprocessblurb etlprocessblurb etlprocessblurb etlprocessblurb .' '. copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt . . .' '. . . . . . . .';
    }
}

@media (max-width:575px) {
    .body-sol-dev {
        font-size: 25px;
        font-weight: bold;
        display: grid;
        grid-template-columns: 8% 20% 10% 2% 20% [titlehoriz-start] 10% 20% 10% [titlehoriz-end];
        grid-template-rows: 65px 100px [title-start] 100px [title-end] 100px 100px 100px 47px 0px 40px 100px 100px 355px 40px 100px 100px 414px 40px 100px 100px 301px 40px 100px 100px 100px 191px 40px;
        grid-template-areas: '. . . . . . . .' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic main_graphic' 'blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2 blackbar2' 'lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt lithic_ethos_txt' '. busanalysttitle busanalysttitle busanalysttitle busanalysttitle . . .' '. busanalystimg busanalystimg . . . . .' '. . . . . . . .' '. busanalystblurb busanalystblurb busanalystblurb busanalystblurb busanalystblurb busanalystblurb .' '. databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle databasedevtitle .' '. databasedevimg databasedevimg . . . . .' '. . . . . . . .' '. databasedevblurb databasedevblurb databasedevblurb databasedevblurb databasedevblurb databasedevblurb .' '. softwaredevtitle softwaredevtitle softwaredevtitle softwaredevtitle . . .' '. softwaredevimg softwaredevimg . . . . .' '. . . . . . . .' '. softwaredevblurb softwaredevblurb softwaredevblurb softwaredevblurb softwaredevblurb softwaredevblurb .' '. etlprocesstitle etlprocesstitle etlprocesstitle etlprocesstitle . . .' '. etlprocessimg etlprocessimg . . . . .' '. . . . . . . .' '. etlprocessblurb etlprocessblurb etlprocessblurb etlprocessblurb etlprocessblurb etlprocessblurb .' '. copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt copyright_lithic_txt . . .' '. . . . . . . .';
    }
}

.img-city-sol-dev {
    width: 100%;
    height: 100%;
    object-fit: cover;
    margin-top: -16px;
    grid-area: main_graphic;
}

.img-logo-sol-dev {
    margin-left: 21px;
    margin-top: 59px;
    grid-area: 1 / 1 / title / 8;
}

.para-heading-sol-dev {
    font-size: 45px;
    font-weight: bold;
    text-align: center;
    flex-wrap: nowrap;
    justify-content: center;
    grid-area: 5 / 2 / 6 / 8;
}

.blackbar-top-sol-dev {
    background-color: #000000;
    grid-area: 1 / 1 / 2 / titlehoriz;
}

.blackbar-bottom-sol-dev {
    background-color: #000000;
    margin-top: -17px;
    margin-bottom: 79px;
    grid-area: 7 / 1 / 9 / titlehoriz;
    padding-top: 41px;
}

.para-heading-bus-analysis-sol-dev {
    font-size: 25px;
    font-weight: bold;
    grid-area: 9 / 2 / 10 / 8;
}

.img-bus-analysis-sol-dev {
    object-fit: cover;
    grid-area: busanalystimg;
    min-width: 250px;
}

.para-blurb-bus-analysis-sol-dev {
    font-size: 20px;
    font-weight: normal;
    margin-top: -8px;
    grid-area: busanalystblurb;
}

.para-heading-datab-dev-sol-dev {
    font-size: 25px;
    font-weight: bold;
    margin-top: -1px;
    padding-bottom: 40px;
    grid-area: databasedevtitle;
}

.img-datab-dev-sol-dev {
    object-fit: cover;
    margin-top: -1px;
    flex-wrap: nowrap;
    grid-area: databasedevimg;
    min-width: 250px;
}

.para-blurb-datab-dev-sol-dev {
    font-size: 20px;
    font-weight: normal;
    margin-top: -8px;
    grid-area: databasedevblurb;
}

.para-heading-soft-dev-sol-dev {
    grid-area: 17 / 2 / 18 / 8;
}

.img-soft-dev-sol-dev {
    object-fit: cover;
    grid-area: softwaredevimg;
    min-width: 250px;
}

.para-blurb-soft-dev-sol-dev {
    font-size: 20px;
    font-weight: normal;
    margin-top: -8px;
    grid-area: softwaredevblurb;
}

.para-heading-etl-proc-sol-dev {
    font-size: 25px;
    font-weight: bold;
    grid-area: etlprocesstitle;
}

.img-etl-proc-sol-dev {
    object-fit: cover;
    grid-area: etlprocessimg;
    min-width: 250px;
}

.para-blurb-etl-proc-sol-dev {
    font-size: 20px;
    font-weight: normal;
    margin-top: -8px;
    grid-area: etlprocessblurb;
}

.para-copyright-sol-dev {
    font-size: 16px;
    font-weight: normal;
    margin-top: -3px;
    padding-top: 8px;
    grid-area: 27 / 2 / 28 / 8;
}

.menu-sol-dev {
    grid-area: 1 / 4 / 2 / titlehoriz;
    justify-content: flex-end;
    flex-wrap: nowrap;
}